हैंडलर API लॉन्च करें

यह कंट्रोल करें कि आपका ऐप्लिकेशन कैसे लॉन्च किया जाता है.

लॉन्च हैंडलर एपीआई की मदद से, यह कंट्रोल किया जा सकता है कि आपका ऐप्लिकेशन कैसे लॉन्च किया जाए. उदाहरण के लिए, यह तय किया जा सकता है कि ऐप्लिकेशन किसी मौजूदा विंडो का इस्तेमाल करे या नई विंडो का. साथ ही, यह भी तय किया जा सकता है कि चुनी गई विंडो को लॉन्च यूआरएल पर ले जाया जाए या नहीं. फ़ाइल मैनेज करने वाले एपीआई की तरह, यह भी लॉन्च किए गए पेज के window.launchQueue में LaunchParams ऑब्जेक्ट को कतार में लगाता है.

मौजूदा स्थिति

चरण स्थिति
1. एक्सप्लेनर बनाना पूरा हो गया
2. स्पेसिफ़िकेशन का शुरुआती ड्राफ़्ट बनाना पूरा हो गया
3. सुझाव/राय पाना और डिज़ाइन को बेहतर बनाना पूरा हुआ
4. ऑरिजिन ट्रायल. पूरा हुआ
5. लॉन्च करें पूरा हो गया

लॉन्च हैंडलर एपीआई का इस्तेमाल करना

ब्राउज़र समर्थन

इंटरफ़ेस

लॉन्च हैंडलर एपीआई में दो नए इंटरफ़ेस तय किए गए हैं.

LaunchParams : यह एक ऐसा ऑब्जेक्ट होता है जिसमें targetURL शामिल होता है. इसे ग्राहक को मैनेज करना होता है. LaunchQueue : यह तब तक लॉन्च नहीं होता, जब तक इसे तय किया गया उपभोक्ता हैंडल नहीं कर लेता.

launch_handler मेनिफ़ेस्ट का सदस्य

अपने ऐप्लिकेशन के लॉन्च होने के तरीके के बारे में साफ़ तौर पर बताने के लिए, अपने मेनिफ़ेस्ट में launch_handler मेनिफ़ेस्ट मेंबर जोड़ें. इसमें एक सब-फ़ील्ड होता है, जिसे client_mode कहा जाता है. इससे यह कंट्रोल किया जा सकता है कि नया या मौजूदा क्लाइंट लॉन्च किया जाना चाहिए या नहीं. साथ ही, यह भी कंट्रोल किया जा सकता है कि इस क्लाइंट को नेविगेट किया जाना चाहिए या नहीं. यहां दिए गए उदाहरण में, ऐसी फ़ाइल दिखाई गई है जिसमें उदाहरण के तौर पर वैल्यू दी गई हैं. इससे सभी लॉन्च हमेशा नए क्लाइंट पर रीडायरेक्ट होंगे.

{   "launch_handler": {     "client_mode": "navigate-new"   } } 

अगर कोई वैल्यू सेट नहीं की जाती है, तो launch_handler की डिफ़ॉल्ट वैल्यू {"client_mode": "auto"} होती है. उप-फ़ील्ड के लिए इस्तेमाल की जा सकने वाली वैल्यू ये हैं:

  • client_mode:
    • navigate-new: लॉन्च के टारगेट यूआरएल को लोड करने के लिए, वेब ऐप्लिकेशन विंडो में नया ब्राउज़िंग कॉन्टेक्स्ट बनाया जाता है.
    • navigate-existing: वेब ऐप्लिकेशन की विंडो में, हाल ही में इस्तेमाल किए गए ब्राउज़िंग कॉन्टेक्स्ट को लॉन्च के टारगेट यूआरएल पर ले जाया जाता है.
    • focus-existing: लॉन्च को मैनेज करने के लिए, वेब ऐप्लिकेशन विंडो में हाल ही में इंटरैक्ट किए गए ब्राउज़िंग कॉन्टेक्स्ट को चुना जाता है. LaunchParams ऑब्जेक्ट को दस्तावेज़ के window.launchQueue में शामिल किया जाएगा. इस ऑब्जेक्ट का targetURL, लॉन्च यूआरएल पर सेट होगा.
    • auto: उपयोगकर्ता एजेंट के पास यह तय करने का विकल्प होता है कि प्लैटफ़ॉर्म के लिए सबसे सही तरीका क्या है. उदाहरण के लिए, मोबाइल डिवाइसों पर सिर्फ़ एक क्लाइंट काम करता है और वे existing-client का इस्तेमाल करते हैं. वहीं, डेस्कटॉप डिवाइसों पर कई विंडो काम करती हैं और वे डेटा के नुकसान से बचने के लिए navigate-new का इस्तेमाल करते हैं.

client_mode प्रॉपर्टी, वैल्यू की सूची (ऐरे) को भी स्वीकार करती है. इसमें पहली मान्य वैल्यू का इस्तेमाल किया जाएगा. ऐसा इसलिए किया गया है, ताकि मौजूदा स्पेसिफ़िकेशन में नई वैल्यू जोड़ी जा सकें. साथ ही, मौजूदा स्पेसिफ़िकेशन के साथ काम करने की सुविधा भी बनी रहे.

उदाहरण के लिए, अगर काल्पनिक वैल्यू "focus-matching-url" जोड़ी जाती है, तो साइटें "focus-matching-url" को तय करेंगी, ताकि वे उन पुराने ब्राउज़र के व्यवहार को कंट्रोल कर सकें जो "focus-matching-url" के साथ काम नहीं करते थे."client_mode": ["focus-matching-url", "navigate-existing"]

window.launchQueue का इस्तेमाल करना

नीचे दिए गए कोड में, extractSongID() फ़ंक्शन, लॉन्च के दौरान पास किए गए यूआरएल से songID को एक्सट्रैक्ट करता है. इसका इस्तेमाल, म्यूज़िक प्लेयर PWA में कोई गाना चलाने के लिए किया जाता है.

if ('launchQueue' in window) {   launchQueue.setConsumer((launchParams) => {     if (launchParams.targetURL) {       const songID = extractSongId(launchParams.targetURL);       if (songID) {         playSong(songID);       }     }   }); } 

डेमो

PWA Launch Handler Demo में, Launch Handler API का डेमो देखा जा सकता है. यह देखने के लिए कि ऐप्लिकेशन, Launch Handler API का इस्तेमाल कैसे करता है, ऐप्लिकेशन का सोर्स कोड ज़रूर देखें.

  1. Musicr 2.0 ऐप्लिकेशन इंस्टॉल करें.
  2. फ़ॉर्म के चैट ऐप्लिकेशन में खुद को एक लिंक भेजें https://mdn.github.io/dom-examples/launch-handler/?track=https://example.com/music.mp3. (ऑडियो फ़ाइल पर ले जाने वाले किसी भी यूआरएल के लिए, https://example.com/music.mp3 को पसंद के मुताबिक बनाया जा सकता है. उदाहरण के लिए, https://mdn.github.io/dom-examples/launch-handler/?track=https://huggingface.co/spaces/VIDraft/PHI4-Multimodal/resolve/main/examples/harvard.wav).
  3. अपने चैट ऐप्लिकेशन में मौजूद लिंक पर क्लिक करें. देखें कि Musicr 2.0 कैसे खुलता है और ट्रैक कैसे चलाता है.
  4. चैट ऐप्लिकेशन में मौजूद लिंक पर फिर से क्लिक करें. ध्यान दें कि आपको Musicr 2.0 का दूसरा इंस्टेंस नहीं मिलेगा.

सुझाव/राय दें या शिकायत करें

Chromium टीम, Launch Handler API के साथ आपके अनुभवों के बारे में जानना चाहती है.

हमें एपीआई डिज़ाइन के बारे में बताएं

क्या एपीआई के बारे में कुछ ऐसा है जो आपकी उम्मीद के मुताबिक काम नहीं करता? इसके अलावा, क्या आपको अपने आइडिया को लागू करने के लिए, कुछ और तरीकों या प्रॉपर्टी की ज़रूरत है? क्या आपको सुरक्षा मॉडल के बारे में कोई सवाल पूछना है या कोई टिप्पणी करनी है? GitHub repo पर, स्पेसिफ़िकेशन से जुड़ी समस्या की शिकायत करें या किसी मौजूदा समस्या के बारे में अपने विचार जोड़ें.

लागू करने से जुड़ी समस्या की शिकायत करना

क्या आपको Chromium के इस्तेमाल में कोई गड़बड़ी मिली? या क्या लागू करने का तरीका, स्पेसिफ़िकेशन से अलग है? new.crbug.com पर जाकर, गड़बड़ी की रिपोर्ट करें. इसमें ज़्यादा से ज़्यादा जानकारी शामिल करें. साथ ही, गड़बड़ी को दोहराने के निर्देश दें. इसके अलावा, कॉम्पोनेंट बॉक्स में Blink>AppManifest डालें.

एपीआई के लिए सहायता दिखाना

क्या आपको Launch Handler API का इस्तेमाल करना है? सार्वजनिक तौर पर आपकी दी गई सहायता से, Chromium टीम को सुविधाओं को प्राथमिकता देने में मदद मिलती है. साथ ही, इससे ब्राउज़र बनाने वाली अन्य कंपनियों को यह पता चलता है कि इन सुविधाओं को सपोर्ट करना कितना ज़रूरी है.

@ChromiumDev को ट्वीट करें. इसके लिए, हैशटैग #LaunchHandler का इस्तेमाल करें. साथ ही, हमें बताएं कि इसका इस्तेमाल कहां और कैसे किया जा रहा है.

मददगार लिंक