ऐस्ट्रो व्यू ट्रांज़िशन

Fred K Schott
Fred K Schott
Matthew Phillips
Matthew Phillips
Maxi Ferreira
Maxi Ferreira
Kara Erickson
Kara Erickson
Addy Osmani
Addy Osmani

आज हम View Transitions API के साथ Chrome और Astro की यात्रा के बारे में ज़्यादा जानकारी देना चाहते हैं. इसमें बताया गया है कि Astro की कम्यूनिटी ने एपीआई को कैसे अपनाया और उससे जुड़े प्रयोग कैसे किए. साथ ही, इसमें यह भी बताया गया है कि इससे कम्यूनिटी को क्या फ़ायदे मिले. हमें यह बताते हुए भी खुशी हो रही है कि Astro 3.0 में, व्यू ट्रांज़िशन के लिए पहले से मौजूद नई सुविधा के बारे में ज़्यादा जानकारी दी जा रही है!

बैकग्राउंड

किसी पेज के अलग-अलग स्टेटस के बीच आसानी से ट्रांज़िशन करना, वेब पर ऐनिमेशन के साथ आसानी से इस्तेमाल किए जा सकने वाले अनुभव बनाने का एक मुश्किल काम रहा है. इसे स्टेटस ट्रांज़िशन कहा जाता है. सीएसएस ट्रांज़िशन, सीएसएस ऐनिमेशन, और वेब ऐनिमेशन एपीआई जैसे टूल उपलब्ध होने के बावजूद, स्टेटस ट्रांज़िशन बनाना मुश्किल काम है. आउटगोइंग एलिमेंट पर इंटरैक्शन को मैनेज करना एक चुनौती है. इससे ट्रांज़िशन ज़्यादा मुश्किल हो सकते हैं.

इसके अलावा, सहायता करने वाले डिवाइसों के लिए, पढ़ने की पोज़िशन और फ़ोकस बनाए रखना मुश्किल होता है. साथ ही, स्क्रोल पोज़िशन में अंतर होने पर, स्टेटस ट्रांज़िशन की प्रोसेस मुश्किल हो जाती है. इन सभी वजहों से, वेबपेज पर अलग-अलग एलिमेंट के बीच आसानी से ट्रांज़िशन लागू करने में मुश्किल आती है

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

Chrome 111 में व्यू ट्रांज़िशन एपीआई के लॉन्च के साथ, JavaScript पर आधारित वेब ऐप्लिकेशन के साथ-साथ सभी वेबसाइटों के लिए ट्रांज़िशन की सुविधा देने की दिशा में काम शुरू हुआ. आने वाले समय में, इसमें और भी बेहतर सुविधाएं जोड़ी जाएंगी. आने वाले समय में, Chrome में कई नई सुविधाएं जोड़ी जा सकती हैं. जैसे, सभी दस्तावेज़ों में ट्रांज़िशन, कंपोजिटर से चलने वाले ऐनिमेशन, स्कोप वाले ट्रांज़िशन, और नेस्ट किए गए ट्रांज़िशन ग्रुप.

View Transitions API की मदद से, कई पेजों वाले पारंपरिक ऐप्लिकेशन को नेटिव ऐप्लिकेशन की तरह आसानी से नेविगेट किया जा सकता है.

डेमो पर जाएं: लाइव, सोर्स

व्यू ट्रांज़िशन की मदद से, एक्सप्लोरेशन की सुविधा को जल्दी उपलब्ध कराना

Chrome ने व्यू ट्रांज़िशन एपीआई के साथ काम करने की शुरुआत, अकेले नहीं की थी. डेवलपर, फ़्रेमवर्क के लेखकों, और सीएसएस वर्किंग ग्रुप के सुझावों और सहयोग से, कई सालों तक इस सुविधा को बेहतर बनाया गया.

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

Astro उन फ़्रेमवर्क में से एक था जो व्यू ट्रांज़िशन की सुविधा का इस्तेमाल शुरुआती दौर से कर रहा था. इस लेख के बाकी हिस्से में, Astro टीम के सदस्यों के अनुभव के बारे में बताया गया है. इसमें वे बताते हैं कि वे वेब डेवलपमेंट के अनुभव को बेहतर बनाने के लिए, व्यू ट्रांज़िशन की सुविधा को कैसे ढूंढते हैं, उसे कैसे अपनाते हैं, और उसे कैसे मुख्य तौर पर इस्तेमाल करते हैं.

Astro, व्यू ट्रांज़िशन पर क्यों भरोसा करता है

Astro को व्यू ट्रांज़िशन जैसी सुविधा का इंतज़ार लंबे समय से था. Astro एक JavaScript वेब फ़्रेमवर्क है. यह आपके यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट को सर्वर-रेंडर करके, उन्हें हल्का एचटीएमएल बनाता है. इससे पेज तेज़ी से लोड होता है. Astro, क्लाइंट डिवाइस से ज़्यादा से ज़्यादा काम को जान-बूझकर हटा देता है. Astro वेबसाइटें, नेटिव ब्राउज़र पेज नेविगेशन का इस्तेमाल करती हैं. वहीं, अन्य वेब फ़्रेमवर्क, JavaScript क्लाइंट-साइड रूटिंग की मदद से ब्राउज़र नेविगेशन को हाइजैक कर सकते हैं.

इस समझौते की वजह से, Astro की टीम को एक समस्या का सामना करना पड़ा: क्लाइंट-साइड रूटिंग का इस्तेमाल किए बिना, Astro कैसे पेज ट्रांज़िशन को ऐनिमेट कर सकता है और सभी पेजों पर ऐप्लिकेशन जैसे यूज़र इंटरफ़ेस (यूआई) को बनाए रख सकता है?

ALT_TEXT_HERE
Astro की मदद से पेज ट्रांज़िशन को ऐनिमेट करने से जुड़ी समस्याएं

इसका जवाब, व्यू ट्रांज़िशन था. व्यू ट्रांज़िशन की मदद से, Astro वही रूटिंग सुविधाएं दे सकता है जो JavaScript पर आधारित ज़्यादातर एसपीए वेब फ़्रेमवर्क देते हैं. हालांकि, इसमें क्लाइंट-साइड रूटिंग की परफ़ॉर्मेंस और जटिलता का ओवरहेड नहीं होता. अन्य फ़्रेमवर्क ने व्यू ट्रांज़िशन को लागू करने की जानकारी के तौर पर देखा, लेकिन Astro के लिए यह बहुत बड़ी बात थी.

ALT_TEXT_HERE
जवाब के तौर पर ट्रांज़िशन देखें

Astro की टीम को अगला सवाल यह पूछना था कि “कैसे?” टीम ने प्रेरणा पाने के लिए, Turbo, Swup, और Livewire जैसे प्रोजेक्ट देखे. साथ ही, Astro में कुछ मिलते-जुलते तरीकों का प्रोटोटाइप भी बनाया.

शुरुआती कोशिशों में से एक, पूरे पेज का “स्मार्ट ट्रांज़िशन” था. यह एचटीएमएल के हर नए पेज की तुलना, मौजूदा एचटीएमएल से अपने-आप करता था. इसके बाद, JavaScript का इस्तेमाल करके हर एलिमेंट को एक साथ बदलने की कोशिश करता था. यह तरीका बेहतर था, लेकिन इसमें गड़बड़ियां होने की संभावना ज़्यादा थी.

// An early API design for enabling view transitions
// in Astro via top-level config. Never implemented.

export default defineConfig({
  router: 'spa'
})

शुक्र है कि Astro कम्यूनिटी ने दिखाया कि View Transitions API पहले से ही बेहतरीन था. इसमें प्रॉडक्ट को ज़्यादा मुश्किल बनाने की ज़रूरत नहीं थी. शुरुआती कुछ डेमो देखने के बाद, Astro टीम को एक आसान Astro API बनाने का आइडिया आया. यह API, ब्राउज़र के API से ज़्यादा से ज़्यादा मिलता-जुलता हो. व्यू ट्रांज़िशन को Astro में छिपी हुई, लागू करने से जुड़ी जानकारी के तौर पर देखने के बजाय, उन्हें सीधे डेवलपर को दिखाया जा सकता है. Astro को सीधे वेब प्लैटफ़ॉर्म के साथ अलाइन करना और फ़्रंटएंड पर पूरी जटिलता को कम करना.

---
// Add a simple fade transition with 2 lines of code!
// 1. Import the <ViewTransitions> component
// 2. Add it to your common/base head component, or individual pages.

import { ViewTransitions } from 'astro:transitions';
---
<head>
  <title>My View Transitions Demo</title>
  <ViewTransitions />
</head>
<!-- ... -->

काम आसान हो गया: Astro में नया व्यू ट्रांज़िशन एपीआई लाएं और अपने-आप फ़ॉलबैक की सुविधा दें, ताकि ज़्यादा से ज़्यादा वेबसाइटों और ब्राउज़र पर ऐप्लिकेशन काम कर सके. फ़ॉलबैक सपोर्ट ज़रूरी है, क्योंकि Chrome के अलावा ज़्यादातर ब्राउज़र में, नेटिव व्यू ट्रांज़िशन की सुविधा पूरी तरह से काम नहीं करती.

Astro में आधिकारिक सहायता लॉन्च करना

Astro ने Astro 2.9 में, व्यू ट्रांज़िशन की सुविधा को एक्सपेरिमेंट के तौर पर रिलीज़ किया है. हमें तुरंत जवाब मिला. डेवलपर ने इस्तेमाल के कई अलग-अलग उदाहरणों के बेहतरीन डेमो शेयर करना शुरू कर दिया. कुछ मामलों में, उन्होंने इसे प्रोडक्शन में भी भेज दिया.

व्यू ट्रांज़िशन के दौरान, वीडियो और ऐनिमेशन चलते रहते हैं. Astro 3.0 में पहले से मौजूद सुविधा की मदद से, ट्रांज़िशन में अलग-अलग रूट में शेयर किए गए एलिमेंट शामिल किए जा सकते हैं.

डेमो पर जाएं: लाइव, सोर्स

Astro 3.0 में, View Transitions API के नए वर्शन के लिए फ़्लैग हटा दिया गया है. साथ ही, इस वर्शन में इस API का इस्तेमाल करने की सुविधा पूरी तरह से उपलब्ध है. ये नए एपीआई, अब एक्सपेरिमेंट के तौर पर या एक साथ इस्तेमाल करने के लिए तैयार हैं.

<main transition:animate="slide">
  <p>Slide animation as you navigate to and from the page!</p>
</main>
<aside transition:name="my-aside">
  <p>Animate and morph the matching "my-aside" element across pages automatically!</p>
</aside>

Astro को प्लैटफ़ॉर्म एपीआई के साथ अलाइन करने का एक अनचाहा फ़ायदा यह है कि नेटिव व्यू ट्रांज़िशन एपीआई के साथ नई सुविधाएं बनाने की कोशिश की जा सकती है. उदाहरण के लिए, Astro transition:persist डायरेक्टिव की मदद से, किसी भी एलिमेंट को पूरे पेज के नेविगेशन में बनाए रखा जा सकता है. इससे, लंबे समय तक चलने वाले एलिमेंट, जैसे कि हमेशा चलने वाले ऑडियो और वीडियो प्लेयर काम करते हैं. पहले, ऐसा सिर्फ़ भारी JavaScript SPAs में ही किया जा सकता था.

<video controls="" autoplay="" transition:persist>
  <source src="https://ia804502.us.archive.org/33/items/GoldenGa1939_3/GoldenGa1939_3_512kb.mp4" type="video/mp4">
</video>
Astro 3.0, पेज नेविगेशन में एचटीएमएल एलिमेंट को बनाए रखने की सुविधा देता है. इंटरैक्टिव यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट को सेव करते समय, उनकी स्थिति भी सेव रहती है.

डेमो पर जाएं: लाइव, सोर्स

Astro, डेवलपर के लिए व्यू ट्रांज़िशन को ज़्यादा बेहतर भी बना सकता है. उदाहरण के लिए, टीम ने पहले ही कस्टम फ़ॉरवर्ड/बैकवर्ड ऐनिमेशन और डाइनैमिक एचटीएमएल के लिए ऐनिमेशन की सुविधा जोड़ दी है. इन दोनों सुविधाओं को सिर्फ़ लोअर-लेवल एपीआई की मदद से लागू करना मुश्किल है. हालांकि, Astro में ये सुविधाएं आसानी से लागू की जा सकती हैं.

फ़िलहाल, ये सुविधाएं सिर्फ़ Astro में उपलब्ध हैं. हालांकि, Astro की टीम उम्मीद करती है कि आने वाले समय में ब्राउज़र को बेहतर बनाने के लिए, वे अपने अनुभव को स्पेसिफ़िकेशन के लेखकों और वर्किंग ग्रुप के साथ शेयर करेंगी. उदाहरण के लिए, प्रस्ताव को बारीकी से मॉनिटर करके, सीएसएस में ऐनिमेशन शेयर करना आसान बनाना.

इसके बाद क्या होता है?

आने वाले समय में, वेब पर व्यू ट्रांज़िशन की सुविधा का ज़्यादा इस्तेमाल किया जा सकता है. Astro, Nuxt, और HTMX ने कुछ हद तक सहायता दी है. साथ ही, कई अन्य ने भी अपनी दिलचस्पी दिखाई है.

Chrome की टीम, Astro में व्यू ट्रांज़िशन की सुविधा के काम करने से बेहद खुश है. यह वेब डेवलपमेंट के लिए एक बड़ा कदम है. इससे उपयोगकर्ताओं को बेहतर और डाइनैमिक अनुभव मिलता है. डेवलपर, हमारा सुझाव है कि आप Astro 3.0 में व्यू ट्रांज़िशन की सुविधा को आज़माएं. नए लैंडिंग पेज बनाते समय या मौजूदा साइटों को अपग्रेड करते समय, ये बेहतर सुविधाएं काफ़ी काम की साबित हो सकती हैं. व्यू ट्रांज़िशन की मदद से, एसपीए और एमपीए के बीच के अंतर को कम किया जा सका. Chrome को यह जानकर खुशी होगी कि एसपीए और/या एमपीए के लिए सहायता में और क्या-क्या कमी है. इस बारे में ज़्यादा जानने के लिए, View Transitions WICG GitHub repo पर बेझिझक टिप्पणी करें.

हमने अब तक जो इनोवेटिव डेमो और ऐप्लिकेशन देखे हैं उनसे हमें काफ़ी प्रेरणा मिली है. हमें और भी ऐसे डेमो और ऐप्लिकेशन देखने हैं. व्यू ट्रांज़िशन के साथ आपके काम से, वेब के भविष्य को आकार मिल रहा है. Astro में व्यू ट्रांज़िशन की सुविधा आज़माएं और अपना काम शेयर करें. साथ ही, इस सफ़र को साथ मिलकर जारी रखें.

अन्य रेफ़रंस