Chrome 124 की खास बातें यहां दी गई हैं:
- दो नए एपीआई हैं, जिनकी मदद से JavaScript से एलान वाले शैडो DOM का इस्तेमाल किया जा सकता है.
- वेब सॉकेट में स्ट्रीम का इस्तेमाल किया जा सकता है.
- व्यू ट्रांज़िशन थोड़े बेहतर हो गए हैं.
- इसके अलावा, और भी बहुत कुछ है.
क्या आपको पूरी जानकारी चाहिए? Chrome 124 के रिलीज़ नोट देखें.
JavaScript में डिक्लेरेटिव शैडो डीओएम का इस्तेमाल करना
दो नए एपीआई हैं, जिनकी मदद से एलान वाले शैडो DOM का इस्तेमाल, JavaScript से किया जा सकता है.
setHTMLUnsafe()
, innerHTML
जैसा ही है. इसकी मदद से, किसी एलिमेंट के अंदरूनी एचटीएमएल को दी गई स्ट्रिंग पर सेट किया जा सकता है. इससे तब मदद मिलती है, जब आपके पास कुछ ऐसे एचटीएमएल होते हैं
जिनमें इस तरह से डिक्लेरेटिव शैडो डीओएम शामिल होता है.
<my-custom-element>
<template shadowrootmode="open">
<style>
:host {
display: block;
color: yellow;
}
</style>
Hello, <slot></slot>
</template>
</my-custom-element>
अगर सिर्फ़ innerHTML
का इस्तेमाल किया जाता है, तो ब्राउज़र इसे सही तरीके से पार्स नहीं करेगा और कोई शैडो DOM नहीं होगा. हालांकि, setHTMLUnsafe()
का इस्तेमाल करने पर, आपका शैडो डीओएम बन जाता है और एलिमेंट को आपकी उम्मीद के मुताबिक पार्स किया जाता है.
const section = document.createElement("section");
section.setHTMLUnsafe(`<my-custom-element>...</my-custom-element>`);
दूसरा एपीआई parseHTMLUnsafe()
है और यह DOMParser.parseFromString()
की तरह ही काम करता है.
ये दोनों एपीआई असुरक्षित हैं. इसका मतलब है कि इनमें इनपुट को सुरक्षित बनाने की कोई प्रोसेस नहीं होती. इसलिए, आपको यह पक्का करना होगा कि उन्हें जो भी खिलाया जा रहा है वह सुरक्षित हो. हमें उम्मीद है कि आने वाले समय में, हम ऐसा वर्शन देखेंगे जिसमें इनपुट को सुरक्षित बनाने की सुविधा होगी.
आखिर में, ये दोनों एपीआई Firefox और Safari के नए वर्शन में पहले से ही काम कर रहे हैं!
WebSocket Stream API
WebSockets, उपयोगकर्ता के ब्राउज़र और सर्वर के बीच डेटा को एक-दूसरे को भेजने का बेहतरीन तरीका है. इसके लिए, आपको पोलिंग पर निर्भर रहने की ज़रूरत नहीं है. यह चैट ऐप्लिकेशन जैसी चीज़ों के लिए बहुत अच्छा है, जिनमें आप कोई जानकारी आते ही उससे निपटना चाहते हैं.
लेकिन, अगर डेटा आपके प्रोसेस करने की क्षमता से ज़्यादा तेज़ी से आता है, तो क्या होगा?
इसे बैक प्रेशर कहा जाता है. इससे आपको गंभीर सिर दर्द हो सकता है. माफ़ करें, WebSocket API में बैकप्रेशर से निपटने का कोई अच्छा तरीका नहीं है.
WebSocket Stream API आपको स्ट्रीम और वेब सॉकेट की सुविधा देता है. इसका मतलब है कि बैक प्रेशर को बिना किसी अतिरिक्त शुल्क के लागू किया जा सकता है.
नया WebSocketStream
बनाकर शुरू करें और उसे WebSocket सर्वर का यूआरएल दें.
const wss = new WebSocketStream(WSS_URL);
const {readable, writable} = await wss.opened;
const reader = readable.getReader();
const writer = writable.getWriter();
while (true) {
const {value, done} = await reader.read();
if (done) {
break;
}
const result = await process(value);
await writer.write(result);
}
इसके बाद, कनेक्शन खुलने का इंतज़ार करें. इससे, ReadableStream
और WritableStream
दिखेगा. ReadableStream.getReader()
तरीके को कॉल करने पर, आपको एक ReadableStreamDefaultReader
मिलता है. इसके बाद, स्ट्रीम खत्म होने तक, उससे डेटा read()
किया जा सकता है.
डेटा लिखने के लिए, WritableStream.getWriter()
तरीके को कॉल करें. यह तरीका आपको WritableStreamDefaultWriter
देता है. इसके बाद, write()
डेटा का इस्तेमाल किया जा सकता है.
ट्रांज़िशन में हुए सुधार देखना
मुझे व्यू ट्रांज़िशन की सुविधाओं को लेकर खुशी हो रही है. Chrome 124 में दो नई सुविधाएं जोड़ी गई हैं, जिन्हें व्यू ट्रांज़िशन को आसान बनाने के लिए डिज़ाइन किया गया है.
जब नेविगेशन किसी दस्तावेज़ को नए दस्तावेज़ से बदलता है, तो pageswap
इवेंट, दस्तावेज़ के विंडो ऑब्जेक्ट पर ट्रिगर होता है.
document.addEventListener("pageswap", event => {
if (!event.viewTransition) {
return;
}
});
साथ ही, दस्तावेज़ को रेंडर होने से रोकने की सुविधा, जिसकी मदद से किसी दस्तावेज़ को तब तक रेंडर होने से रोका जा सकता है, जब तक कि ज़रूरी कॉन्टेंट को पार्स नहीं कर लिया जाता. इससे सभी ब्राउज़र पर एक जैसा फ़र्स्ट पेंट पक्का होता है.
और भी कई सुविधाएं!
बेशक वहां और भी बहुत कुछ है.
disallowReturnToOpener
ब्राउज़र को यह संकेत देता है कि उसे पिक्चर में पिक्चर विंडो में ऐसा बटन नहीं दिखाना चाहिए जिससे उपयोगकर्ता, वीडियो खोलने वाले टैब पर वापस जा सके.कीबोर्ड से फ़ोकस किए जा सकने वाले स्क्रोल कंटेनर, स्क्रोल कंटेनर को फ़ोकस करने लायक बनाकर, ऐक्सेस को बेहतर बनाते हैं. इसके लिए, वे क्रम से फ़ोकस करने की सुविधा का इस्तेमाल करते हैं.
यूनिवर्सल इंस्टॉल की सुविधा की मदद से, उपयोगकर्ता किसी भी पेज को इंस्टॉल कर सकते हैं. भले ही, वह मौजूदा PWA की शर्तों को पूरा न करता हो.
इसके बारे में और पढ़ें
इसमें सिर्फ़ कुछ खास हाइलाइट शामिल हैं. Chrome 124 में किए गए अन्य बदलावों के बारे में जानने के लिए, नीचे दिए गए लिंक देखें.
- Chrome 124 के रिलीज़ नोट
- Chrome DevTools (124) में नया क्या है
- Chrome 124 के लिए ChromeStatus.com के अपडेट
- Chromium सोर्स रिपॉज़िटरी में हुए बदलावों की सूची
- Chrome के रिलीज़ कैलेंडर की जानकारी
सदस्यता लें
अप-टू-डेट रहने के लिए, Chrome डेवलपर के YouTube चैनल की सदस्यता लें. ऐसा करने पर, जब भी हम कोई नया वीडियो लॉन्च करेंगे, आपको ईमेल से सूचना मिलेगी.
मेरा नाम पीट लेपेज है. Chrome 125 के रिलीज़ होने के बाद, हम आपको बताएंगे कि Chrome में नया क्या है!