सीएसएस पर बेहतर कंट्रोल, अलग-अलग ट्रांसफ़ॉर्म प्रॉपर्टी के साथ बदल जाता है

translate, rotate, और scale प्रॉपर्टी की मदद से एलिमेंट को बदलें

सीएसएस की transform प्रॉपर्टी

किसी एलिमेंट पर ट्रांसफ़ॉर्म लागू करने के लिए, सीएसएस transform प्रॉपर्टी का इस्तेमाल करें. प्रॉपर्टी में एक या उससे ज़्यादा <transform-function> स्वीकार किए जाते हैं, जो एक के बाद एक लागू होते हैं.

.target {
  transform: translateX(50%) rotate(30deg) scale(1.2);
}

X-ऐक्सिस पर, टारगेट किए गए एलिमेंट का 50% अनुवाद किया जाता है. इसके बाद, इसे 30 डिग्री घुमाया जाता है और आखिर में, इसे 120% तक बढ़ाया जाता है.

transform प्रॉपर्टी अपने काम को ठीक से करती है. हालांकि, उनमें से किसी भी वैल्यू में अलग से बदलाव करने पर, थोड़ी परेशानी होती है.

होवर पर स्केल बदलने के लिए, आपको ट्रांसफ़ॉर्म प्रॉपर्टी में सभी फ़ंक्शन का डुप्लीकेट बनाना होगा, भले ही उनकी वैल्यू में कोई बदलाव न हो.

.target:hover {
  transform: translateX(50%) rotate(30deg) scale(2); /* Only the value of scale() changed */
}

अलग-अलग ट्रांसफ़ॉर्म प्रॉपर्टी

Chrome 104 में शिपिंग, सीएसएस ट्रांसफ़ॉर्म के लिए अलग-अलग प्रॉपर्टी हैं. scale, rotate, और translate प्रॉपर्टी हैं. इनका इस्तेमाल, ट्रांसफ़ॉर्मेशन के अलग-अलग हिस्सों के बारे में अलग-अलग जानकारी देने के लिए किया जा सकता है.

ऐसा करने से, Chrome Firefox और Safari को जोड़ देता है जो पहले से ही इन प्रॉपर्टी का समर्थन करते हैं.

ब्राउज़र के इस्तेमाल से जुड़ी सहायता

  • Chrome: 104.
  • Edge: 104.
  • Firefox: 72.
  • Safari: 14.1.

सोर्स

अलग-अलग प्रॉपर्टी के साथ, पिछले transform उदाहरण को फिर से लिखने पर, आपका स्निपेट इस तरह दिखता है:

.target {
  translate: 50% 0;
  rotate: 30deg;
  scale: 1.2;
}

ऑर्डर से जुड़े मामले

ओरिजनल सीएसएस transform प्रॉपर्टी और नई प्रॉपर्टी के बीच एक मुख्य अंतर यह है कि एलान किए गए ट्रांसफ़ॉर्मेशन किस क्रम में लागू होते हैं.

transform का इस्तेमाल करने पर, ट्रांसफ़ॉर्मेशन फ़ंक्शन उसी क्रम में लागू होते हैं जिस क्रम में उन्हें लिखा गया है. जैसे, बाईं ओर (बाहर) से दाईं ओर (अंदर).

अलग-अलग ट्रांसफ़ॉर्मेशन प्रॉपर्टी के लिए, क्रम वही नहीं होता है जिसमें उन्हें एलान किया जाता है. यह क्रम हमेशा एक जैसा होता है: पहले translate (बाहर से), फिर rotate, और फिर scale (अंदर).

इसका मतलब है कि नीचे दिए गए दोनों कोड स्निपेट एक जैसे नतीजे देते हैं:

.transform--individual {
  translate: 50% 0;
  rotate: 30deg;
  scale: 1.2;
}

.transform--individual-alt {
  rotate: 30deg;
  translate: 50% 0;
  scale: 1.2;
}

दोनों ही मामलों में, टारगेट किए गए एलिमेंट का अनुवाद पहले 50%, X-ऐक्सिस पर किया जाएगा, फिर 30deg की मदद से घुमाया जाएगा, और आखिर में 1.2 की मदद से स्केल किया जाएगा.

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

ऐनिमेशन

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

कीफ़्रेम का ग्राफ़.

transform का इस्तेमाल करना

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

इंटरमीडिएट वैल्यू के साथ कैलकुलेट किया गया मुख्य फ़्रेम ग्राफ़.

इससे मिलने वाला सीएसएस कोड इस तरह का होगा:

@keyframes anim {
  0% { transform: translateX(0%); }
  5% { transform: translateX(5%) rotate(90deg) scale(1.2); }
  10% { transform: translateX(10%) rotate(180deg) scale(1.2); }
  90% { transform: translateX(90%) rotate(180deg) scale(1.2); }
  95% { transform: translateX(95%) rotate(270deg) scale(1.2); }
  100% { transform: translateX(100%) rotate(360deg); }
}

.target {
  animation: anim 2s;
  animation-fill-mode: forwards;
}

अलग-अलग ट्रांसफ़ॉर्म प्रॉपर्टी का इस्तेमाल करना

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

@keyframes anim {
  0% { translate: 0% 0; }
  100% { translate: 100% 0; }

  0%, 100% { scale: 1; }
  5%, 95% { scale: 1.2; }

  0% { rotate: 0deg; }
  10%, 90% { rotate: 180deg; }
  100% { rotate: 360deg; }
}

.target {
  animation: anim 2s;
  animation-fill-mode: forwards;
}

अलग-अलग ट्रांसफ़ॉर्म प्रॉपर्टी और कई कीफ़्रेम का इस्तेमाल करना

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

@keyframes move {
  0% { translate: 0% 0; }
  100% { translate: 100% 0; }
}

@keyframes scale {
  0%, 100% { scale: 1; }
  5%, 95% { scale: 1.2; }
}

@keyframes rotate {
  0% { rotate: 0deg; }
  10%, 90% { rotate: 180deg; }
  100% { rotate: 360deg; }
}

.target {
  animation: move 2s, scale 2s, rotate 2s;
  animation-fill-mode: forwards;
}

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

परफ़ॉर्मेंस

इन नई प्रॉपर्टी का इस्तेमाल करने वाले ऐनिमेशन, मौजूदा transform प्रॉपर्टी के ऐनिमेशन की तरह ही काम करते हैं.

translate, rotate, और scale के ऐनिमेशन, कॉम्पोज़िटर पर उसी तरह चलते हैं जिस तरह transform के ऐनिमेशन चलते हैं. इसलिए, ये transform की तरह ही ऐनिमेशन की परफ़ॉर्मेंस के लिए अच्छे हैं.

ये नई प्रॉपर्टी, will-change प्रॉपर्टी के साथ भी काम करती हैं. आम तौर पर, will-change का ज़रूरत से ज़्यादा इस्तेमाल करने से बचना चाहिए. इसके लिए, इसे कम से कम एलिमेंट पर और जितना हो सके उतने कम समय के लिए इस्तेमाल करें. हालांकि, ज़्यादा से ज़्यादा सटीक जानकारी देना भी अच्छा होता है. उदाहरण के लिए, अगर rotate और filter प्रॉपर्टी की मदद से किसी ऐनिमेशन को ऑप्टिमाइज़ करने के लिए will-change का इस्तेमाल किया जा रहा है, तो आपको will-change: rotate, filter का इस्तेमाल करके इसकी जानकारी देनी चाहिए. rotate और filter को ऐनिमेट करने के मामले में, यह will-change: transform, filter का इस्तेमाल करने से थोड़ा बेहतर है. इसकी वजह यह है कि will-change का इस्तेमाल करने पर, Chrome पहले से कुछ डेटा स्ट्रक्चर बनाता है. ये स्ट्रक्चर, transform और rotate के लिए अलग-अलग होते हैं.

नई इंटरऑपरेबल सीरीज़ का हिस्सा