एक पेज के ऐप्लिकेशन के लिए, एक ही दस्तावेज़ वाले व्यू में ट्रांज़िशन

जब व्यू ट्रांज़िशन किसी एक दस्तावेज़ पर चलता है, तो उसे एक ही दस्तावेज़ का व्यू ट्रांज़िशन कहा जाता है. आम तौर पर, ऐसा सिंगल-पेज ऐप्लिकेशन (एसपीए) में होता है, जहां डीओएम को अपडेट करने के लिए JavaScript का इस्तेमाल किया जाता है. Chrome 111 से, एक ही दस्तावेज़ के व्यू के बीच ट्रांज़िशन की सुविधा काम करती है.

समान दस्तावेज़ वाले व्यू का ट्रांज़िशन ट्रिगर करने के लिए, document.startViewTransition को कॉल करें:

function handleClick(e) {
  // Fallback for browsers that don't support this API:
  if (!document.startViewTransition) {
    updateTheDOMSomehow();
    return;
  }

  // With a View Transition:
  document.startViewTransition(() => updateTheDOMSomehow());
}

शुरू होने पर, ब्राउज़र उन सभी एलिमेंट के स्नैपशॉट अपने-आप कैप्चर करता है जिनमें view-transition-name सीएसएस प्रॉपर्टी दी गई है.

इसके बाद, यह कॉलबैक में पास किए गए डेटा को एक्ज़ीक्यूट करता है, जो डीओएम को अपडेट करता है. इसके बाद, यह नई स्थिति के स्नैपशॉट लेता है.

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


डिफ़ॉल्ट ट्रांज़िशन: क्रॉस-फ़ेड

डिफ़ॉल्ट व्यू ट्रांज़िशन, क्रॉस-फ़ेड होता है. इसलिए, यह एपीआई के बारे में बेहतर जानकारी देता है:

function spaNavigate(data) {
  // Fallback for browsers that don't support this API:
  if (!document.startViewTransition) {
    updateTheDOMSomehow(data);
    return;
  }

  // With a transition:
  document.startViewTransition(() => updateTheDOMSomehow(data));
}

जहां updateTheDOMSomehow, DOM को नई स्थिति में बदलता है. ऐसा किसी भी तरीके से किया जा सकता है. उदाहरण के लिए, एलिमेंट जोड़े या हटाए जा सकते हैं, क्लास के नाम बदले जा सकते हैं या स्टाइल बदली जा सकती हैं.

इस तरह, पेज क्रॉस-फ़ेड होते हैं:

डिफ़ॉल्ट क्रॉस-फ़ेड. कम से कम डेमो. सोर्स.

ठीक है, क्रॉस-फ़ेड उतना शानदार नहीं है. अच्छी बात यह है कि ट्रांज़िशन को पसंद के मुताबिक बनाया जा सकता है, लेकिन इसके लिए पहले आपको यह समझना होगा कि यह बुनियादी क्रॉस-फ़ेड कैसे काम करता है.


ये ट्रांज़िशन कैसे काम करते हैं

आइए, पिछले कोड सैंपल को अपडेट करते हैं.

document.startViewTransition(() => updateTheDOMSomehow(data));

.startViewTransition() को कॉल करने पर, एपीआई पेज की मौजूदा स्थिति कैप्चर करता है. इसमें, स्नैपशॉट लेना भी शामिल है.

प्रोसेस पूरी होने के बाद, .startViewTransition() को पास किए गए कॉलबैक को कॉल किया जाता है. यहीं पर डीओएम बदला जाता है. इसके बाद, एपीआई पेज की नई स्थिति कैप्चर करता है.

नया स्टेट कैप्चर होने के बाद, एपीआई इस तरह का स्यूडो-एलिमेंट ट्री बनाता है:

::view-transition
└─ ::view-transition-group(root)
   └─ ::view-transition-image-pair(root)
      ├─ ::view-transition-old(root)
      └─ ::view-transition-new(root)

::view-transition, पेज पर मौजूद बाकी सभी चीज़ों के ऊपर एक ओवरले में मौजूद है. यह तब काम आता है, जब आपको ट्रांज़िशन के लिए बैकग्राउंड का रंग सेट करना हो.

::view-transition-old(root), पुराने व्यू का स्क्रीनशॉट है और ::view-transition-new(root), नए व्यू का लाइव वर्शन है. दोनों, सीएसएस 'बदले गए कॉन्टेंट' (जैसे कि <img>) के तौर पर रेंडर होते हैं.

पुराना व्यू opacity: 1 से opacity: 0 पर ऐनिमेट होता है, जबकि नया व्यू opacity: 0 से opacity: 1 में ऐनिमेट होता है. इससे क्रॉस-फ़ेड बन जाता है.

सभी ऐनिमेशन, सीएसएस ऐनिमेशन का इस्तेमाल करके दिखाए जाते हैं. इसलिए, उन्हें सीएसएस की मदद से पसंद के मुताबिक बनाया जा सकता है.

ट्रांज़िशन को पसंद के मुताबिक बनाएं

व्यू ट्रांज़िशन के सभी नकली एलिमेंट को सीएसएस की मदद से टारगेट किया जा सकता है. साथ ही, ऐनिमेशन को सीएसएस का इस्तेमाल करके तय किया जाता है, इसलिए मौजूदा सीएसएस ऐनिमेशन प्रॉपर्टी का इस्तेमाल करके उनमें बदलाव किया जा सकता है. उदाहरण के लिए:

::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 5s;
}

इस एक बदलाव से, फ़ेड अब बहुत धीमा हो गया है:

लंबा क्रॉस-फ़ेड. कम से कम डेमो. सोर्स.

ठीक है, यह अब भी काफ़ी नहीं है. इसके बजाय, नीचे दिया गया कोड Material Design के शेयर किए गए ऐक्सिस ट्रांज़िशन को लागू करता है:

@keyframes fade-in {
  from { opacity: 0; }
}

@keyframes fade-out {
  to { opacity: 0; }
}

@keyframes slide-from-right {
  from { transform: translateX(30px); }
}

@keyframes slide-to-left {
  to { transform: translateX(-30px); }
}

::view-transition-old(root) {
  animation: 90ms cubic-bezier(0.4, 0, 1, 1) both fade-out,
    300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-to-left;
}

::view-transition-new(root) {
  animation: 210ms cubic-bezier(0, 0, 0.2, 1) 90ms both fade-in,
    300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-from-right;
}

और नतीजा यह रहा:

शेयर किया गया ऐक्सिस ट्रांज़िशन. कम से कम डेमो. सोर्स.

एक से ज़्यादा एलिमेंट को ट्रांज़िशन करना

पिछले डेमो में, शेयर किए गए ऐक्सिस ट्रांज़िशन में पूरा पेज शामिल है. यह ज़्यादातर पेज के लिए काम करता है, लेकिन हेडिंग के लिए यह सही नहीं लगता, क्योंकि यह सिर्फ़ फिर से स्लाइड करने के लिए स्लाइड आउट करता है.

इससे बचने के लिए, हेडर को पेज के बाकी हिस्से से अलग किया जा सकता है, ताकि उसे अलग से ऐनिमेट किया जा सके. ऐसा करने के लिए, एलिमेंट को view-transition-name असाइन किया जाता है.

.main-header {
  view-transition-name: main-header;
}

view-transition-name की वैल्यू, आपकी पसंद के मुताबिक हो सकती है. हालांकि, none को छोड़कर, इसका मतलब है कि ट्रांज़िशन का कोई नाम नहीं है. इसका इस्तेमाल ट्रांज़िशन के दौरान एलिमेंट की खास तरीके से पहचान करने के लिए किया जाता है.

और इसका नतीजा:

फ़िक्स्ड हेडर के साथ शेयर किए गए ऐक्सिस का ट्रांज़िशन. कम से कम डेमो. सोर्स.

अब हेडर अपनी जगह पर बना रहता है और क्रॉस-फ़ेड हो जाता है.

उस सीएसएस एलान की वजह से, स्यूडो-एलिमेंट ट्री बदल गया:

::view-transition
├─ ::view-transition-group(root)
│  └─ ::view-transition-image-pair(root)
│     ├─ ::view-transition-old(root)
│     └─ ::view-transition-new(root)
└─ ::view-transition-group(main-header)
   └─ ::view-transition-image-pair(main-header)
      ├─ ::view-transition-old(main-header)
      └─ ::view-transition-new(main-header)

अब दो ट्रांज़िशन ग्रुप हैं. एक हेडर के लिए और दूसरा बाकी के लिए. इन्हें सीएसएस की मदद से, अलग-अलग टारगेट किया जा सकता है और अलग-अलग ट्रांज़िशन दिए जा सकते हैं. हालांकि, इस मामले में main-header को डिफ़ॉल्ट ट्रांज़िशन के साथ छोड़ दिया गया था, जो कि क्रॉस-फ़ेड है.

ठीक है, डिफ़ॉल्ट ट्रांज़िशन सिर्फ़ क्रॉस फ़ेड नहीं होता. ::view-transition-group भी ट्रांज़िशन करता है:

  • पोज़िशन और ट्रांसफ़ॉर्म (transform का इस्तेमाल करके)
  • चौड़ाई
  • ऊंचाई

अब तक इसका कोई असर नहीं पड़ा है, क्योंकि हेडर का साइज़ और डीओएम के दोनों तरफ़ की पोज़िशन पहले जैसी ही है. हालांकि, हेडर में मौजूद टेक्स्ट को भी निकाला जा सकता है:

.main-header-text {
  view-transition-name: main-header-text;
  width: fit-content;
}

fit-content का इस्तेमाल इसलिए किया जाता है, ताकि एलिमेंट, बाकी चौड़ाई तक स्ट्रेच होने के बजाय, टेक्स्ट के साइज़ का हो. ऐसा न करने पर, बैक ऐरो दोनों पेजों में एक जैसा साइज़ होने के बजाय, हेडर टेक्स्ट एलिमेंट का साइज़ कम कर देता है.

इसलिए, अब हमारे पास तीन हिस्से हैं:

::view-transition
├─ ::view-transition-group(root)
│  └─ …
├─ ::view-transition-group(main-header)
│  └─ …
└─ ::view-transition-group(main-header-text)
   └─ …

हालांकि, फिर से डिफ़ॉल्ट सेटिंग का इस्तेमाल करें:

हेडर टेक्स्ट को स्लाइड करना. कम से कम डेमो. सोर्स.

अब हेडिंग टेक्स्ट की मदद से स्क्रीन पर पीछे वाले बटन के लिए जगह बनाई जा सकती है.


view-transition-class की मदद से, कई स्यूडो एलिमेंट को एक ही तरह से ऐनिमेट करें

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

  • Chrome: 125. अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
  • किनारा: 125.
  • Firefox: यह सुविधा काम नहीं करती. अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
  • Safari: यह सुविधा काम नहीं करती. अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है

मान लें कि आपके पास कार्ड के साथ-साथ पेज पर एक टाइटल वाला व्यू ट्रांज़िशन है. टाइटल को छोड़कर सभी कार्ड को ऐनिमेट करने के लिए, आपको ऐसा सिलेक्टर लिखना होगा जो हर कार्ड को टारगेट करता हो.

h1 {
    view-transition-name: title;
}
::view-transition-group(title) {
    animation-timing-function: ease-in-out;
}

#card1 { view-transition-name: card1; }
#card2 { view-transition-name: card2; }
#card3 { view-transition-name: card3; }
#card4 { view-transition-name: card4; }

#card20 { view-transition-name: card20; }

::view-transition-group(card1),
::view-transition-group(card2),
::view-transition-group(card3),
::view-transition-group(card4),

::view-transition-group(card20) {
    animation-timing-function: var(--bounce);
}

क्या आपको 20 एलिमेंट मिले? आपको ये 20 सिलेक्टर लिखने होंगे. क्या आपको कोई नया एलिमेंट जोड़ना है? इसके बाद, आपको ऐनिमेशन स्टाइल लागू करने वाले सिलेक्टर को भी बड़ा करना होगा. पूरी तरह से स्केलेबल नहीं है.

स्टाइल का नियम लागू करने के लिए, view-transition-class का इस्तेमाल व्यू ट्रांज़िशन स्यूडो-एलिमेंट में किया जा सकता है.

#card1 { view-transition-name: card1; }
#card2 { view-transition-name: card2; }
#card3 { view-transition-name: card3; }
#card4 { view-transition-name: card4; }
#card5 { view-transition-name: card5; }

#card20 { view-transition-name: card20; }

#cards-wrapper > div {
  view-transition-class: card;
}
html::view-transition-group(.card) {
  animation-timing-function: var(--bounce);
}

इस कार्ड के उदाहरण में, पिछले सीएसएस स्निपेट का इस्तेमाल किया गया है. सभी कार्ड, जिनमें नए कार्ड भी शामिल हैं, पर एक ही समय लागू होता है. इसके लिए, एक सिलेक्टर का इस्तेमाल किया जाता है: html::view-transition-group(.card).

कार्ड के डेमो की रिकॉर्डिंग. view-transition-class का इस्तेमाल करके, जोड़े गए या हटाए गए कार्ड को छोड़कर, सभी कार्ड पर एक ही animation-timing-function लागू होता है.

ट्रांज़िशन डीबग करना

व्यू ट्रांज़िशन, सीएसएस ऐनिमेशन के ऊपर बनाए जाते हैं. इसलिए, Chrome DevTools का ऐनिमेशन पैनल, ट्रांज़िशन को डीबग करने के लिए बहुत अच्छा है.

ऐनिमेशन पैनल का इस्तेमाल करके, अगले ऐनिमेशन को रोका जा सकता है. इसके बाद, ऐनिमेशन को आगे-पीछे किया जा सकता है. इस दौरान, ट्रांज़िशन के स्यूडो-एलिमेंट एलिमेंट पैनल में देखे जा सकते हैं.

Chrome DevTools की मदद से व्यू ट्रांज़िशन को डीबग करना.

ट्रांज़िशन करने वाले एलिमेंट, एक ही डीओएम एलिमेंट होने ज़रूरी नहीं हैं

अब तक, हमने हेडर और हेडर में मौजूद टेक्स्ट के लिए अलग-अलग ट्रांज़िशन एलिमेंट बनाने के लिए, view-transition-name का इस्तेमाल किया है. डीओएम में बदलाव होने से पहले और बाद में, ये कॉन्सेप्ट के हिसाब से एक ही एलिमेंट होते हैं. हालांकि, ऐसे ट्रांज़िशन भी बनाए जा सकते हैं जिनमें ऐसा नहीं होता.

उदाहरण के लिए, एम्बेड किए गए मुख्य वीडियो के लिए view-transition-name दिया जा सकता है:

.full-embed {
  view-transition-name: full-embed;
}

इसके बाद, थंबनेल पर क्लिक करने पर, ट्रांज़िशन के दौरान वही view-transition-name दिया जा सकता है:

thumbnail.onclick = async () => {
  thumbnail.style.viewTransitionName = 'full-embed';

  document.startViewTransition(() => {
    thumbnail.style.viewTransitionName = '';
    updateTheDOMSomehow();
  });
};

और नतीजा:

एक एलिमेंट से दूसरे एलिमेंट में ट्रांज़िशन करना. कम से कम डेमो. सोर्स.

थंबनेल अब मुख्य इमेज में बदल जाएगा. हालांकि, ये कॉन्सेप्ट के हिसाब से (और असल में) अलग-अलग एलिमेंट हैं, लेकिन ट्रांज़िशन एपीआई उन्हें एक ही चीज़ मानता है, क्योंकि इनमें एक ही view-transition-name शेयर किया गया है.

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


कस्टम एंट्री और एग्ज़िट ट्रांज़िशन

इस उदाहरण पर एक नज़र डालें:

साइडबार में जाना और उससे बाहर निकलना. कम से कम डेमो. सोर्स.

साइडबार, ट्रांज़िशन का हिस्सा है:

.sidebar {
  view-transition-name: sidebar;
}

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

::view-transition
├─ …other transition groups…
└─ ::view-transition-group(sidebar)
   └─ ::view-transition-image-pair(sidebar)
      ├─ ::view-transition-old(sidebar)
      └─ ::view-transition-new(sidebar)

हालांकि, अगर साइडबार सिर्फ़ नए पेज पर है, तो ::view-transition-old(sidebar) स्यूडो-एलिमेंट वहां नहीं होगा. चूंकि कोई 'पुराना' नहीं है साइडबार के लिए इमेज, इमेज-पेयर में सिर्फ़ ::view-transition-new(sidebar) होगा. इसी तरह, अगर साइडबार सिर्फ़ पुराने पेज पर है, तो इमेज-पेयर में सिर्फ़ ::view-transition-old(sidebar) होगा.

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

एंट्री और एक्सिट ट्रांज़िशन बनाने के लिए, :only-child स्यूडो-क्लास का इस्तेमाल किया जा सकता है. इससे, पुराने या नए स्यूडो-एलिमेंट को टारगेट किया जा सकता है. ऐसा तब किया जा सकता है, जब इमेज-पेयर में सिर्फ़ एक चाइल्ड एलिमेंट हो:

/* Entry transition */
::view-transition-new(sidebar):only-child {
  animation: 300ms cubic-bezier(0, 0, 0.2, 1) both fade-in,
    300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-from-right;
}

/* Exit transition */
::view-transition-old(sidebar):only-child {
  animation: 150ms cubic-bezier(0.4, 0, 1, 1) both fade-out,
    300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-to-right;
}

इस मामले में, दोनों स्थितियों में साइडबार के मौजूद होने पर कोई ट्रांज़िशन नहीं होता, क्योंकि डिफ़ॉल्ट तौर पर यह सबसे सही होता है.

एक साथ काम नहीं करने वाले डीओएम अपडेट और कॉन्टेंट के लिए इंतज़ार करना

.startViewTransition() को पास किया गया कॉलबैक, एक प्रॉमिस दिखा सकता है. इससे डीओएम को अलग-अलग समय पर अपडेट किया जा सकता है. साथ ही, अहम कॉन्टेंट के तैयार होने का इंतज़ार किया जा सकता है.

document.startViewTransition(async () => {
  await something;
  await updateTheDOMSomehow();
  await somethingElse;
});

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

अगर आपको इमेज या फ़ॉन्ट के तैयार होने का इंतज़ार करना है, तो बहुत ज़्यादा टाइम आउट का इस्तेमाल करना न भूलें:

const wait = ms => new Promise(r => setTimeout(r, ms));

document.startViewTransition(async () => {
  updateTheDOMSomehow();

  // Pause for up to 100ms for fonts to be ready:
  await Promise.race([document.fonts.ready, wait(100)]);
});

हालांकि, कुछ मामलों में देरी से बचने और पहले से मौजूद कॉन्टेंट का ही इस्तेमाल करना बेहतर होता है.


अपने मौजूदा कॉन्टेंट का पूरा फ़ायदा लें

जब थंबनेल बड़ी इमेज में बदल जाता है, तो:

थंबनेल, बड़ी इमेज में ट्रांज़िशन करता हुआ. डेमो साइट को आज़माएं.

डिफ़ॉल्ट ट्रांज़िशन, क्रॉस-फ़ेड होता है. इसका मतलब है कि थंबनेल, अभी तक लोड नहीं हुई पूरी इमेज के साथ क्रॉस-फ़ेड हो सकता है.

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

::view-transition-old(full-embed),
::view-transition-new(full-embed) {
  /* Prevent the default animation,
  so both views remain opacity:1 throughout the transition */
  animation: none;
  /* Use normal blending,
  so the new view sits on top and obscures the old view */
  mix-blend-mode: normal;
}

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

अगर नए व्यू में पारदर्शिता की सुविधा है, तो यह काम नहीं करेगा. हालांकि, इस मामले में हमें पता है कि ऐसा नहीं है. इसलिए, हम यह ऑप्टिमाइज़ेशन कर सकते हैं.

आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) में हुए बदलावों को मैनेज करना

फ़िलहाल, सभी ट्रांज़िशन एक ही आसपेक्ट रेशियो वाले एलिमेंट के लिए किए गए हैं. हालांकि, ऐसा हमेशा नहीं होगा. क्या होगा, अगर थंबनेल का साइज़ 1:1 है और मुख्य इमेज 16:9 है?

आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) में बदलाव के साथ, एक एलिमेंट दूसरे में बदल रहा है. कम से कम डेमो. सोर्स.

डिफ़ॉल्ट ट्रांज़िशन में, ग्रुप पहले वाले साइज़ से बाद के साइज़ में ऐनिमेट होता है. पुराने और नए व्यू, ग्रुप की 100% चौड़ाई और अपने-आप तय होने वाली ऊंचाई के होते हैं. इसका मतलब है कि ग्रुप के साइज़ के बावजूद, इनका आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) नहीं बदलता.

यह डिफ़ॉल्ट तौर पर सेट होने वाला अच्छा विकल्प है. हालांकि, इस मामले में यह विकल्प सही नहीं है. इसलिए:

::view-transition-old(full-embed),
::view-transition-new(full-embed) {
  /* Prevent the default animation,
  so both views remain opacity:1 throughout the transition */
  animation: none;
  /* Use normal blending,
  so the new view sits on top and obscures the old view */
  mix-blend-mode: normal;
  /* Make the height the same as the group,
  meaning the view size might not match its aspect-ratio. */
  height: 100%;
  /* Clip any overflow of the view */
  overflow: clip;
}

/* The old view is the thumbnail */
::view-transition-old(full-embed) {
  /* Maintain the aspect ratio of the view,
  by shrinking it to fit within the bounds of the element */
  object-fit: contain;
}

/* The new view is the full image */
::view-transition-new(full-embed) {
  /* Maintain the aspect ratio of the view,
  by growing it to cover the bounds of the element */
  object-fit: cover;
}

इसका मतलब है कि चौड़ाई बढ़ने पर भी थंबनेल, एलिमेंट के बीच में ही रहता है. हालांकि, 1:1 से 16:9 में बदलने पर पूरी इमेज 'बिना काटी गई' दिखती है.

ज़्यादा जानकारी के लिए, ट्रांज़िशन देखना: आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) में होने वाले बदलावों को मैनेज करना देखें


डिवाइस की अलग-अलग स्थितियों के लिए ट्रांज़िशन बदलने के लिए, मीडिया क्वेरी का इस्तेमाल करना

हो सकता है कि आप मोबाइल बनाम डेस्कटॉप पर अलग-अलग ट्रांज़िशन का इस्तेमाल करना चाहें. उदाहरण के लिए, यह उदाहरण जो मोबाइल पर साइड से पूरी स्लाइड दिखाता है, लेकिन डेस्कटॉप पर ज़्यादा आसान स्लाइड दिखाता है:

एक एलिमेंट का दूसरे एलिमेंट में ट्रांज़िशन किया जा रहा है. कम से कम डेमो. सोर्स.

सामान्य मीडिया क्वेरी का इस्तेमाल करके ऐसा किया जा सकता है:

/* Transitions for mobile */
::view-transition-old(root) {
  animation: 300ms ease-out both full-slide-to-left;
}

::view-transition-new(root) {
  animation: 300ms ease-out both full-slide-from-right;
}

@media (min-width: 500px) {
  /* Overrides for larger displays.
  This is the shared axis transition from earlier in the article. */
  ::view-transition-old(root) {
    animation: 90ms cubic-bezier(0.4, 0, 1, 1) both fade-out,
      300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-to-left;
  }

  ::view-transition-new(root) {
    animation: 210ms cubic-bezier(0, 0, 0.2, 1) 90ms both fade-in,
      300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-from-right;
  }
}

आपके पास यह बदलने का विकल्प भी है कि मैच होने वाली मीडिया क्वेरी के आधार पर, किन एलिमेंट को view-transition-name असाइन किया जाए.


कम की गई गति पर प्रतिक्रिया दें प्राथमिकता

उपयोगकर्ता यह बता सकते हैं कि वे अपने ऑपरेटिंग सिस्टम के ज़रिए, कम मोशन में वीडियो देखना पसंद करते हैं. साथ ही, यह भी बताया जा सकता है कि उनकी प्राथमिकता सीएसएस में उपलब्ध है.

आपके पास इन उपयोगकर्ताओं के लिए किसी भी ट्रांज़िशन को रोकने का विकल्प होता है:

@media (prefers-reduced-motion) {
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*) {
    animation: none !important;
  }
}

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


व्यू ट्रांज़िशन टाइप की मदद से, एक से ज़्यादा व्यू ट्रांज़िशन स्टाइल मैनेज करना

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

  • Chrome: 125. अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
  • किनारा: 125.
  • Firefox: समर्थित नहीं. अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
  • Safari: समर्थित नहीं.

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

पेज पर नंबर डालने के डेमो की रिकॉर्डिंग. यह इस बात पर निर्भर करता है कि आपको किस पेज पर जाना है.

इसके लिए, व्यू ट्रांज़िशन टाइप का इस्तेमाल किया जा सकता है. इससे, किसी चालू व्यू ट्रांज़िशन में एक या उससे ज़्यादा टाइप असाइन किए जा सकते हैं. उदाहरण के लिए, पेजेशन क्रम में किसी ऊपरी पेज पर ट्रांज़िशन करते समय, forwards टाइप का इस्तेमाल करें. वहीं, किसी निचले पेज पर जाने के लिए, backwards टाइप का इस्तेमाल करें. ये टाइप सिर्फ़ ट्रांज़िशन कैप्चर करने या करने के दौरान चालू होते हैं. साथ ही, अलग-अलग ऐनिमेशन का इस्तेमाल करने के लिए, हर टाइप को सीएसएस की मदद से पसंद के मुताबिक बनाया जा सकता है.

एक ही दस्तावेज़ के व्यू के ट्रांज़िशन में टाइप का इस्तेमाल करने के लिए, types को startViewTransition तरीके में पास करें. इसकी अनुमति देने के लिए, document.startViewTransition एक ऑब्जेक्ट भी स्वीकार करता है: update एक कॉलबैक फ़ंक्शन है जो डीओएम को अपडेट करता है और types, टाइप वाला एक कलेक्शन है.

const direction = determineBackwardsOrForwards();

const t = document.startViewTransition({
  update: updateTheDOMSomehow,
  types: ['slide', direction],
});

इन टाइप के जवाब देने के लिए, :active-view-transition-type() सिलेक्टर का इस्तेमाल करें. जिस type को टारगेट करना है उसे सिलेक्टर में पास करें. इससे, एक-दूसरे के एलान में रुकावट डाले बिना, कई व्यू ट्रांज़िशन के स्टाइल को अलग-अलग रखा जा सकता है.

टाइप सिर्फ़ ट्रांज़िशन कैप्चर करने या करने पर लागू होते हैं. इसलिए, सिलेक्टर का इस्तेमाल करके किसी एलिमेंट पर view-transition-name को सिर्फ़ उस टाइप के व्यू ट्रांज़िशन के लिए सेट या अनसेट किया जा सकता है.

/* Determine what gets captured when the type is forwards or backwards */
html:active-view-transition-type(forwards, backwards) {
  :root {
    view-transition-name: none;
  }
  article {
    view-transition-name: content;
  }
  .pagination {
    view-transition-name: pagination;
  }
}

/* Animation styles for forwards type only */
html:active-view-transition-type(forwards) {
  &::view-transition-old(content) {
    animation-name: slide-out-to-left;
  }
  &::view-transition-new(content) {
    animation-name: slide-in-from-right;
  }
}

/* Animation styles for backwards type only */
html:active-view-transition-type(backwards) {
  &::view-transition-old(content) {
    animation-name: slide-out-to-right;
  }
  &::view-transition-new(content) {
    animation-name: slide-in-from-left;
  }
}

/* Animation styles for reload type only (using the default root snapshot) */
html:active-view-transition-type(reload) {
  &::view-transition-old(root) {
    animation-name: fade-out, scale-down;
  }
  &::view-transition-new(root) {
    animation-delay: 0.25s;
    animation-name: fade-in, scale-up;
  }
}

नीचे दिए गए पेज नंबर दिखाने के डेमो में, पेज का कॉन्टेंट उस पेज नंबर के हिसाब से आगे या पीछे स्लाइड होता है जिस पर आप नेविगेट कर रहे हैं. ये टाइप, उस क्लिक के आधार पर तय होते हैं जिस पर उन्हें document.startViewTransition में पास कर दिया जाता है.

किसी भी ऐक्टिव व्यू के ट्रांज़िशन को टारगेट करने के लिए, इसके बजाय :active-view-transition pseudo-class सिलेक्टर का इस्तेमाल किया जा सकता है. भले ही, वह किसी भी टाइप का हो.

html:active-view-transition {
    
}

व्यू ट्रांज़िशन रूट पर क्लास के नाम की मदद से, व्यू ट्रांज़िशन के कई स्टाइल मैनेज करना

कभी-कभी एक खास तरह के व्यू से दूसरे व्यू में होने वाले ट्रांज़िशन के लिए, खास तौर पर तैयार किया गया ट्रांज़िशन होना चाहिए. या 'वापस जाएं' नेविगेशन 'आगे' से अलग होना चाहिए नेविगेशन.

'वापस' जाने पर भिन्न ट्रांज़िशन. कम से कम डेमो. सोर्स.

ट्रांज़िशन के टाइप से पहले, इन मामलों को हैंडल करने का तरीका ट्रांज़िशन रूट पर अस्थायी तौर पर क्लास का नाम सेट करना था. document.startViewTransition को कॉल करते समय, यह ट्रांज़िशन रूट <html> एलिमेंट होता है. इसे JavaScript में document.documentElement का इस्तेमाल करके ऐक्सेस किया जा सकता है:

if (isBackNavigation) {
  document.documentElement.classList.add('back-transition');
}

const transition = document.startViewTransition(() =>
  updateTheDOMSomehow(data)
);

try {
  await transition.finished;
} finally {
  document.documentElement.classList.remove('back-transition');
}

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

अब ट्रांज़िशन बदलने के लिए, अपनी सीएसएस में उस क्लास के नाम का इस्तेमाल किया जा सकता है:

/* 'Forward' transitions */
::view-transition-old(root) {
  animation: 90ms cubic-bezier(0.4, 0, 1, 1) both fade-out,
    300ms cubic-bezier(0.4, 0, 0.2, 1) both slide-to-left;
}

::view-transition-new(root) {
  animation: 210ms cubic-bezier(0, 0, 0.2, 1) 90ms both fade-in, 300ms
      cubic-bezier(0.4, 0, 0.2, 1) both slide-from-right;
}

/* Overrides for 'back' transitions */
.back-transition::view-transition-old(root) {
  animation-name: fade-out, slide-to-right;
}

.back-transition::view-transition-new(root) {
  animation-name: fade-in, slide-from-left;
}

मीडिया क्वेरी की तरह ही, इन क्लास की मौजूदगी का इस्तेमाल, यह बदलने के लिए भी किया जा सकता है कि कौनसे एलिमेंट को view-transition-name मिले.


अन्य ऐनिमेशन को फ़्रीज़ किए बिना ट्रांज़िशन चलाएं

वीडियो ट्रांज़िशन की पोज़िशन का डेमो देखें:

वीडियो ट्रांज़िशन. कम से कम डेमो. सोर्स.

क्या आपको इसमें कोई गड़बड़ी दिखी? अगर आपने नहीं दिखाया है, तो चिंता न करें. यहां इसे धीमा करके दिखाया गया है:

वीडियो ट्रांज़िशन, धीमा. कम से कम डेमो. सोर्स.

ट्रांज़िशन के दौरान, वीडियो फ़्रीज़ होने लगता है. इसके बाद, वीडियो का वर्शन फ़ेड इन हो जाता है. ऐसा इसलिए है, क्योंकि ::view-transition-old(video) पुराने व्यू का स्क्रीनशॉट है, जबकि ::view-transition-new(video) नए व्यू की लाइव इमेज है.

इसे ठीक किया जा सकता है, लेकिन पहले खुद से पूछें कि क्या इसे ठीक करना सही होगा. अगर आपको 'समस्या' जब ट्रांज़िशन अपनी सामान्य रफ़्तार से चल रहा था, तो मुझे इसे बदलने के बारे में कोई चिंता नहीं थी.

अगर आपको इसे ठीक करना है, तो ::view-transition-old(video) न दिखाएं. सीधे ::view-transition-new(video) पर स्विच करें. डिफ़ॉल्ट स्टाइल और ऐनिमेशन को बदलकर ऐसा किया जा सकता है:

::view-transition-old(video) {
  /* Don't show the frozen old view */
  display: none;
}

::view-transition-new(video) {
  /* Don't fade the new view in */
  animation: none;
}

यह बहुत आसान है!

वीडियो ट्रांज़िशन, धीमा. कम से कम डेमो. सोर्स.

अब ट्रांज़िशन के दौरान वीडियो चलता रहता है.


JavaScript के साथ ऐनिमेट करना

अब तक, सभी ट्रांज़िशन सीएसएस का इस्तेमाल करके तय किए गए हैं, लेकिन कभी-कभी सीएसएस काफ़ी नहीं होती:

सर्कल का ट्रांज़िशन. कम से कम डेमो. सोर्स.

इस ट्रांज़िशन के कुछ हिस्सों को सिर्फ़ सीएसएस की मदद से पूरा नहीं किया जा सकता:

  • ऐनिमेशन, क्लिक की जगह से शुरू होता है.
  • ऐनिमेशन, सबसे दूर के कोने तक त्रिज्या वाले सर्कल पर खत्म होता है. हालांकि, हमें उम्मीद है कि आने वाले समय में सीएसएस की मदद से ऐसा हो पाएगा.

हालांकि, Web Animation API का इस्तेमाल करके ट्रांज़िशन बनाए जा सकते हैं!

let lastClick;
addEventListener('click', event => (lastClick = event));

function spaNavigate(data) {
  // Fallback for browsers that don't support this API:
  if (!document.startViewTransition) {
    updateTheDOMSomehow(data);
    return;
  }

  // Get the click position, or fallback to the middle of the screen
  const x = lastClick?.clientX ?? innerWidth / 2;
  const y = lastClick?.clientY ?? innerHeight / 2;
  // Get the distance to the furthest corner
  const endRadius = Math.hypot(
    Math.max(x, innerWidth - x),
    Math.max(y, innerHeight - y)
  );

  // With a transition:
  const transition = document.startViewTransition(() => {
    updateTheDOMSomehow(data);
  });

  // Wait for the pseudo-elements to be created:
  transition.ready.then(() => {
    // Animate the root's new view
    document.documentElement.animate(
      {
        clipPath: [
          `circle(0 at ${x}px ${y}px)`,
          `circle(${endRadius}px at ${x}px ${y}px)`,
        ],
      },
      {
        duration: 500,
        easing: 'ease-in',
        // Specify which pseudo-element to animate
        pseudoElement: '::view-transition-new(root)',
      }
    );
  });
}

इस उदाहरण में transition.ready का इस्तेमाल किया गया है. यह एक प्रॉमिस है, जो ट्रांज़िशन के स्यूडो-एलिमेंट बन जाने के बाद रिज़ॉल्व हो जाता है. इस ऑब्जेक्ट की अन्य प्रॉपर्टी के बारे में एपीआई रेफ़रंस में बताया गया है.


बेहतर बनाने के लिए ट्रांज़िशन

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

ट्रांज़िशन को बेहतर बनाने के लिए, ट्रांज़िशन प्रॉमिस का इस्तेमाल इस तरह से न करें कि ट्रांज़िशन पूरा न होने पर आपका ऐप्लिकेशन क्रैश हो जाए.

यह न करें
async function switchView(data) {
  // Fallback for browsers that don't support this API:
  if (!document.startViewTransition) {
    await updateTheDOM(data);
    return;
  }

  const transition = document.startViewTransition(async () => {
    await updateTheDOM(data);
  });

  await transition.ready;

  document.documentElement.animate(
    {
      clipPath: [`inset(50%)`, `inset(0)`],
    },
    {
      duration: 500,
      easing: 'ease-in',
      pseudoElement: '::view-transition-new(root)',
    }
  );
}

इस उदाहरण में समस्या यह है कि अगर ट्रांज़िशन ready की स्थिति तक नहीं पहुंच पाता है, तो switchView() को अस्वीकार कर दिया जाएगा. हालांकि, इसका मतलब यह नहीं है कि व्यू स्विच नहीं किया जा सका. हो सकता है कि डीओएम अपडेट हो गया हो, लेकिन उसमें डुप्लीकेट view-transition-name हों, इसलिए ट्रांज़िशन को स्किप कर दिया गया.

इसके बजाय:

यह करें
async function switchView(data) {
  // Fallback for browsers that don't support this API:
  if (!document.startViewTransition) {
    await updateTheDOM(data);
    return;
  }

  const transition = document.startViewTransition(async () => {
    await updateTheDOM(data);
  });

  animateFromMiddle(transition);

  await transition.updateCallbackDone;
}

async function animateFromMiddle(transition) {
  try {
    await transition.ready;

    document.documentElement.animate(
      {
        clipPath: [`inset(50%)`, `inset(0)`],
      },
      {
        duration: 500,
        easing: 'ease-in',
        pseudoElement: '::view-transition-new(root)',
      }
    );
  } catch (err) {
    // You might want to log this error, but it shouldn't break the app
  }
}

इस उदाहरण में, डीओएम अपडेट होने का इंतज़ार करने और अपडेट न होने पर उसे अस्वीकार करने के लिए, transition.updateCallbackDone का इस्तेमाल किया गया है. ट्रांज़िशन पूरा न होने पर, switchView अब अस्वीकार नहीं करता. यह डीओएम अपडेट पूरा होने पर हल हो जाता है और पूरा न होने पर अस्वीकार कर देता है.

अगर आपको switchView को तब रिज़ॉल्व करना है, जब नया व्यू 'सेटल' हो गया हो, जैसे कि ऐनिमेशन वाला कोई ट्रांज़िशन पूरा हो गया हो या उसे स्किप करके आखिर तक पहुंचा गया हो, तो transition.updateCallbackDone को transition.finished से बदलें.


यह कोई पॉलीफ़िल नहीं है, लेकिन…

इस सुविधा को पॉलीफ़िल करना आसान नहीं है. हालांकि, यह हेल्पर फ़ंक्शन उन ब्राउज़र में चीज़ों को बहुत आसान बना देता है जो व्यू ट्रांज़िशन के साथ काम नहीं करते:

function transitionHelper({
  skipTransition = false,
  types = [],
  update,
}) {

  const unsupported = (error) => {
    const updateCallbackDone = Promise.resolve(update()).then(() => {});

    return {
      ready: Promise.reject(Error(error)),
      updateCallbackDone,
      finished: updateCallbackDone,
      skipTransition: () => {},
      types,
    };
  }

  if (skipTransition || !document.startViewTransition) {
    return unsupported('View Transitions are not supported in this browser');
  }

  try {
    const transition = document.startViewTransition({
      update,
      types,
    });

    return transition;
  } catch (e) {
    return unsupported('View Transitions with types are not supported in this browser');
  }
}

इसका इस्तेमाल इस तरह से किया जा सकता है:

function spaNavigate(data) {
  const types = isBackNavigation ? ['back-transition'] : [];

  const transition = transitionHelper({
    update() {
      updateTheDOMSomehow(data);
    },
    types,
  });

  // …
}

जिन ब्राउज़र पर व्यू ट्रांज़िशन की सुविधा काम नहीं करती उनमें updateDOM को अब भी कॉल किया जाएगा. हालांकि, इसमें ऐनिमेशन वाला ट्रांज़िशन नहीं होगा.

ट्रांज़िशन के दौरान, <html> में जोड़ने के लिए कुछ classNames भी दिए जा सकते हैं. इससे नेविगेशन के टाइप के हिसाब से ट्रांज़िशन को आसानी से बदला जा सकता है.

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


फ़्रेमवर्क के साथ काम करना

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

  • React—यहां मुख्य बात flushSync है, जो स्टेटस में हुए बदलावों के सेट को सिंक करके लागू करता है. हां, उस एपीआई का इस्तेमाल करने के बारे में एक बड़ी चेतावनी दी गई है. हालांकि, डैन अब्रामोव ने मुझे भरोसा दिलाया है कि इस मामले में यह सही है. React और असाइन किए गए कोड की तरह ही, startViewTransition से मिले अलग-अलग प्रॉमिस का इस्तेमाल करते समय, ध्यान रखें कि आपका कोड सही स्थिति में चल रहा हो.
  • Vue.js—यहां nextTick कुंजी है, जो डीओएम के अपडेट होने के बाद काम करती है.
  • Svelte—यह काफ़ी हद तक Vue से मिलता-जुलता है, लेकिन अगले बदलाव के लिए इंतज़ार करने का तरीका tick है.
  • Lit—यह अहम है कि कॉम्पोनेंट में this.updateComplete प्रॉमिस किया गया है. यह डीओएम अपडेट होने के बाद काम करता है.
  • Angular—यहां applicationRef.tick कुंजी है, जो DOM में किए गए बदलावों को फ़्लश करता है. Angular के वर्शन 17 में, @angular/router के साथ मिलने वाले withViewTransitions का इस्तेमाल किया जा सकता है.

एपीआई का संदर्भ

const viewTransition = document.startViewTransition(update)

नया ViewTransition शुरू करें.

update एक फ़ंक्शन है, जिसे दस्तावेज़ की मौजूदा स्थिति कैप्चर होने के बाद कॉल किया जाता है.

इसके बाद, जब updateCallback से मिला प्रॉमिस पूरा हो जाता है, तो अगले फ़्रेम में ट्रांज़िशन शुरू हो जाता है. अगर updateCallback से मिलने वाला प्रॉमिस अस्वीकार कर देता है, तो ट्रांज़िशन रद्द कर दिया जाता है.

const viewTransition = document.startViewTransition({ update, types })

तय किए गए टाइप के साथ नया ViewTransition शुरू करना

दस्तावेज़ की मौजूदा स्थिति कैप्चर होने के बाद, update को कॉल किया जाता है.

types, ट्रांज़िशन कैप्चर या परफ़ॉर्म करते समय, ट्रांज़िशन के लिए ऐक्टिव टाइप सेट करता है. शुरुआत में यह खाली रहती है. ज़्यादा जानकारी के लिए, viewTransition.types पर और नीचे देखें.

ViewTransition के इंस्टेंस मेंबर:

viewTransition.updateCallbackDone

ऐसा प्रॉमिस जो updateCallback के दिए गए प्रॉमिस को पूरा करने पर पूरा करता है या उसे अस्वीकार करने पर उसे अस्वीकार कर देता है.

View Transition API, DOM में किए गए बदलाव को रैप करता है और ट्रांज़िशन बनाता है. हालांकि, कभी-कभी आपको ट्रांज़िशन ऐनिमेशन के सफल या फ़ेल होने की परवाह नहीं होती, बस आपको यह जानना है कि डीओएम में बदलाव हुआ है या नहीं और यह कब होता है. updateCallbackDone उसी इस्तेमाल के उदाहरण के लिए है.

viewTransition.ready

यह एक ऐसा वादा है जो ट्रांज़िशन के लिए सूडो-एलिमेंट बनने और ऐनिमेशन शुरू होने के बाद पूरा होता है.

अगर ट्रांज़िशन शुरू नहीं हो पाता है, तो यह न्योता अस्वीकार कर देता है. ऐसा गलत तरीके से कॉन्फ़िगर करने की वजह से हो सकता है, जैसे कि डुप्लीकेट view-transition-name या updateCallback, अस्वीकार किए गए प्रॉमिस को दिखाता है.

यह JavaScript के साथ ट्रांज़िशन स्यूडो-एलिमेंट को ऐनिमेट करने के लिए फ़ायदेमंद है.

viewTransition.finished

यह एक ऐसा प्रॉमिस है जो तब पूरा होता है, जब उपयोगकर्ता को आखिरी स्टेटस पूरी तरह से दिखता है और वह उससे इंटरैक्ट कर सकता है.

यह सिर्फ़ तब अस्वीकार होता है, जब updateCallback अस्वीकार किए गए प्रॉमिस को दिखाता है. इससे पता चलता है कि आखिरी स्थिति नहीं बनाई गई थी.

ऐसा नहीं होने पर, अगर ट्रांज़िशन शुरू नहीं हो पाता है या ट्रांज़िशन के दौरान उसे स्किप कर दिया जाता है, तब भी ट्रांज़िशन की प्रोसेस खत्म हो जाती है. इसलिए, finished पूरा करता है.

viewTransition.types

Set जैसा ऑब्जेक्ट, जिसमें ऐक्टिव व्यू ट्रांज़िशन के टाइप होते हैं. एंट्री में बदलाव करने के लिए, इसके इंस्टेंस के तरीके clear(), add(), और delete() का इस्तेमाल करें.

सीएसएस में किसी खास टाइप का रिस्पॉन्स देने के लिए, ट्रांज़िशन रूट पर :active-view-transition-type(type) pseudo-class सिलेक्टर का इस्तेमाल करें.

व्यू ट्रांज़िशन पूरा होने के बाद, टाइप अपने-आप हट जाते हैं.

viewTransition.skipTransition()

ट्रांज़िशन के ऐनिमेशन वाले हिस्से को स्किप करें.

इससे updateCallback को कॉल करना स्किप नहीं होगा, क्योंकि डीओएम बदलाव, ट्रांज़िशन से अलग होता है.


डिफ़ॉल्ट स्टाइल और ट्रांज़िशन रेफ़रंस

::view-transition
रूट pseudo-element जो व्यूपोर्ट को भरता है और जिसमें हर ::view-transition-group शामिल होता है.
::view-transition-group

बिल्कुल सही जगह पर है.

'पहले' और 'बाद' स्टेटस के बीच ट्रांज़िशन width और height.

व्यूपोर्ट-स्पेस क्वॉड के 'पहले' और 'बाद' के बीच ट्रांज़िशन transform.

::view-transition-image-pair

ग्रुप को भरने के लिए पूरी तरह से सही पोज़िशन में है.

इसमें isolation: isolate है, जो पुराने और नए व्यू पर mix-blend-mode के असर को सीमित करता है.

::view-transition-new और ::view-transition-old

रैपर के ऊपर बाईं ओर ठीक स्थिति में है.

ग्रुप की चौड़ाई का 100% भर जाता है, लेकिन इसकी ऊंचाई अपने-आप सेट हो जाती है. इसलिए, ग्रुप को भरने के बजाय, यह अपने आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) को बनाए रखेगा.

mix-blend-mode: plus-lighter की मदद से, क्रॉस-फ़ेड की सुविधा चालू की जा सकती है.

पुराने व्यू को opacity: 1 से opacity: 0 में बदल दिया जाता है. नया व्यू opacity: 0 से opacity: 1 में बदल जाता है.


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

डेवलपर के सुझाव, शिकायत या राय का हमेशा स्वागत है. ऐसा करने के लिए, GitHub पर सीएसएस वर्किंग ग्रुप के साथ समस्या दर्ज करें. साथ ही, सुझाव और सवाल भी सबमिट करें. [css-view-transitions] से जुड़ी अपनी समस्या प्रीफ़िक्स करें.

अगर आपको कोई गड़बड़ी मिलती है, तो Chromium में गड़बड़ी की शिकायत करें.