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

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

आज हम 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 के अलावा ज़्यादातर ब्राउज़र में, नेटिव व्यू ट्रांज़िशन की सुविधा पूरी तरह से काम नहीं करती.

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

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

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

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

Astro 3.0 में, View Transitions 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 में व्यू ट्रांज़िशन की सुविधा आज़माएं और अपना काम शेयर करें. साथ ही, इस सफ़र को साथ मिलकर जारी रखें.

अन्य रेफ़रंस