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

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

Thomas Steiner
Thomas Steiner

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

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

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

लॉन्च हैंडलर API का इस्तेमाल करना

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

लॉन्च हैंडलर की सुविधा सिर्फ़ ChromeOS पर उपलब्ध है.

ब्राउज़र सहायता

  • 110
  • 110
  • x
  • x

सोर्स

इंटरफ़ेस

Launch हैंडलर API की मदद से दो नए इंटरफ़ेस बनाए गए हैं.

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" जोड़ी गई थी, तो साइटें "client_mode": ["focus-matching-url", "navigate-existing"] को तय करेगी, ताकि उन पुराने ब्राउज़र के काम करने का तरीका कंट्रोल किया जा सके जो "focus-matching-url" के साथ काम नहीं करते.

window.launchVLOOKUP का इस्तेमाल किया जा रहा है

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

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

डेमो

PWA लॉन्च हैंडलर के डेमो में, लॉन्च हैंडलर एपीआई का डेमो देखा जा सकता है. ऐप्लिकेशन के सोर्स कोड को देखना न भूलें, ताकि आप��ो पता चल सके कि यह Launch हैंडलर API का इस्तेमाल कैसे करता है.

  1. ChromeOS डिवाइस पर Musicr 2.0 ऐप्लिकेशन इंस्टॉल करें.
  2. https://launch-handler.glitch.me?track=https://example.com/music.mp3 फ़ॉर्म वाले चैट ऐप्लिकेशन में खुद को एक लिंक भेजें. (ऑडियो फ़ाइल पर ले जाने वाले किसी भी यूआरएल के लिए, https://example.com/music.mp3 को पसंद के मुताबिक बनाया जा सकता है, जैसे कि https://launch-handler.glitch.me?track=https://cdn.glitch.me/3e952c9c-4d6d-4de4-9873-23cf976b422e%2Ffile_example_MP3_700KB.mp3?v=1638795977190).
  3. अपने चैट ऐप्लिकेशन में दिए गए लिंक पर क्लिक करें और देखें कि Musicr 2.0 कैसे खुलता है और ट्रैक को कैसे चलाता है.
  4. अपने चैट ऐप्लिकेशन में दिए गए लिंक पर फिर से क्लिक करें और देखें कि आपको Musicr 2.0 का दूसरा इंस्टेंस नहीं मिलेगा.

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

Chromium की टीम, Launch हैंडलर API के इस्तेमाल से जुड़े आपके अनुभव जानना चाहती है.

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

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

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

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

��ह एपीआई काम करता है

क्या आपको लॉन्च हैंडलर एपीआई इस्तेमाल करना है? आपकी सार्वजनिक सहायता से Chromium टीम को सुविधाओं को प्राथमिकता देने में मदद मिलती है. साथ ही, यह दूसरे ब्राउज़र वेंडर को यह भी दिखाता है कि उनकी मदद करना कितना ज़रूरी है.

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

मददगार लिंक