লেখক-সংজ্ঞায়িত CSS নাম এবং ছায়া DOM একসাথে কাজ করার কথা। যাইহোক, ব্রাউজারগুলি স্পেসিফিকেশনের সাথে অসঙ্গতিপূর্ণ, কখনও কখনও একে অপরের সাথে, এবং প্রতিটি CSS নাম কিছুটা ভিন্ন উপায়ে বেমানান।
এই নিবন্ধটি ছায়া স্কোপ জুড়ে লেখক-সংজ্ঞায়িত CSS নামগুলি কীভাবে আচরণ করে তার বর্তমান অবস্থা নথিভুক্ত করে, এই আশার সাথে যে এটি অদূর ভবিষ্যতে আন্তঃকার্যক্ষমতা উন্নত করার জন্য একটি নির্দেশিকা হিসাবে কাজ করতে পারে।
লেখক-সংজ্ঞায়িত CSS নাম কি?
লেখক-সংজ্ঞায়িত CSS নামগুলি হল একটি অপেক্ষাকৃত পুরানো CSS সিনট্যাক্স প্রক্রিয়া, মূলত @keyframes
নিয়মের জন্য প্রবর্তন করা হয়েছে, যা একটি <keyframe-name>
একটি কাস্টম-আইডেন্ট বা একটি স্ট্রিং হিসাবে সংজ্ঞায়িত করে। এই ধারণার উদ্দেশ্য হল একটি স্টাইলশীটের একটি অংশে কিছু ঘোষণা করা এবং অন্য অংশে এটি উল্লেখ করা।
/* "fade-in" is a CSS name, representing a set of keyframes */
@keyframes fade-in {
from { opacity: 0 };
to { opacity: 1 }
}
.card {
/* "fade-in" is a reference to the above keyframes */
animation-name: fade-in;
}
অন্যান্য CSS বৈশিষ্ট্যগুলি যেগুলি CSS নামগুলি ব্যবহার করে তা হল ফন্ট, সম্পত্তি ঘোষণা, কন্টেইনার কোয়েরি, এবং আরও সাম্প্রতিক ভিউ ট্রানজিশন, অ্যাঙ্কর পজিশনিং এবং স্ক্রোল-চালিত অ্যানিমেশন। নিম্নলিখিত অ-বিস্তৃত সারণীতে এমন নাম অন্তর্ভুক্ত রয়েছে যেগুলির অবস্থা Chrome চেক করে৷
বৈশিষ্ট্য | নাম ঘোষণা | নামের রেফারেন্স |
---|---|---|
কীফ্রেম | @keyframes | animation-name |
হরফ | @font-face { } @font-palette-values | font-family font-palette |
সম্পত্তি ঘোষণা | @property কোনো অনিবন্ধিত কাস্টম সম্পত্তি ঘোষণা | var() |
রূপান্তর দেখুন | view-transition-name view-transition-class | ::view-transition-* সিউডো উপাদান |
অ্যাঙ্কর পজিশনিং | anchor-name | position-anchor |
স্ক্রোল-চালিত অ্যানিমেশন | view-timeline-name scroll-timeline-name | animation-timeline |
শৈলী তালিকা | @counter-style | list-style |
কাউন্টার | counter-reset counter-set counter-increment | |
ধারক প্রশ্ন | container-name | @container |
পাতা | page | @page |
আপনি টেবিলে দেখতে পাচ্ছেন, একটি CSS নামের সাধারণত একটি সংশ্লিষ্ট CSS রেফারেন্স থাকে। উদাহরণস্বরূপ, animation-name
হল @keyframes
নামের একটি রেফারেন্স। CSS নামগুলি DOM-এ সংজ্ঞায়িত নামের থেকে আলাদা, যেমন অ্যাট্রিবিউট এবং ট্যাগ নাম, কারণ সেগুলি ঘোষণা করা হয় তারপর স্টাইলশীটের প্রসঙ্গে উল্লেখ করা হয়।
নামগুলি ছায়া DOM এর সাথে কীভাবে সম্পর্কিত
যদিও CSS নামগুলি একটি নথি বা স্টাইলশীটের বিভিন্ন অংশের মধ্যে সম্পর্ক তৈরি করার জন্য তৈরি করা হয়, তবে Shadow DOM এর বিপরীত কাজ করার জন্য তৈরি করা হয়। এটি সম্পর্ককে এনক্যাপসুলেট করে যাতে তারা ওয়েব কম্পোনেন্ট জুড়ে ফাঁস না করে যেগুলির নিজস্ব নামস্থান থাকার কথা।
CSS নাম এবং ছায়া DOM একসাথে আনার মাধ্যমে, ওয়েব উপাদানগুলি রচনা করার অভিজ্ঞতাটি নমনীয় হওয়ার জন্য যথেষ্ট অভিব্যক্তিপূর্ণ মনে হওয়া উচিত কিন্তু স্থিতিশীল হওয়ার জন্য যথেষ্ট সীমাবদ্ধ।
এই তত্ত্ব ভাল. অনুশীলনে, ব্রাউজারগুলি একই ব্রাউজারে, ব্রাউজার জুড়ে এবং বৈশিষ্ট্য এবং স্পেসিফিকেশনের মধ্যে উভয় বৈশিষ্ট্যের মধ্যে, ছায়া DOM-এর সাথে যেভাবে CSS নামগুলি ইন্টারঅপারেটিং করে তাতে অসামঞ্জস্যপূর্ণ।
কিভাবে নাম এবং ছায়া DOM একসাথে কাজ করা উচিত
সমস্যাটি বোঝার জন্য, সিএসএস-এর এই অংশগুলিকে তত্ত্বগতভাবে কীভাবে একসাথে কাজ করা উচিত তা বোঝার মতো।
সাধারণ নিয়ম
ছায়া গাছ জুড়ে CSS নামগুলি কীভাবে আচরণ করে তার সাধারণ নিয়ম CSS স্কোপিং লেভেল 1 স্পেসিফিকেশনে সংজ্ঞায়িত করা হয়েছে। সংক্ষিপ্ত করার জন্য: একটি CSS নাম যে স্কোপের মধ্যে এটি সংজ্ঞায়িত করা হয়েছে তার মধ্যে বিশ্বব্যাপী, যার অর্থ এটি বংশধর ছায়া গাছ থেকে অ্যাক্সেস করা যেতে পারে, কিন্তু ভাই বা পূর্বপুরুষ ছায়া গাছ থেকে নয়। মনে রাখবেন যে এটি ওয়েব প্ল্যাটফর্মের নামগুলির মতো নয় যেমন উপাদান আইডি, যা একই গাছের সুযোগের মধ্যে এনক্যাপসুলেট করা হয়।
নিয়মের ব্যতিক্রম: @property
অন্যান্য CSS নামের বিপরীতে, CSS বৈশিষ্ট্য ছায়া DOM দ্বারা এনক্যাপসুলেট করা হয় না । বরং, তারা বিভিন্ন ছায়া গাছ জুড়ে পরামিতি পাস করার সাধারণ উপায়। এটি @property
বর্ণনাকারীকে বিশেষ করে তোলে: এটি একটি নথি-বিশ্বব্যাপী ঘোষণার মতো আচরণ করা উচিত যা একটি নির্দিষ্ট নামযুক্ত সম্পত্তি কীভাবে কাজ করে তা সংজ্ঞায়িত করে। কারণ প্রপার্টিগুলিকে ছায়া গাছ জুড়ে মেলাতে হবে, সম্পত্তির ঘোষণার অমিল অপ্রত্যাশিত ফলাফল তৈরি করবে, তাই @property
ঘোষণাগুলিকে নথির ক্রম অনুসারে সমতল এবং সমাধান করার জন্য নির্দিষ্ট করা হয়েছে।
নিয়মের সাথে কিভাবে কাজ করা উচিত ::part
ছায়ার অংশগুলি ছায়া গাছের ভিতরের একটি উপাদানকে তার মূল গাছের সাথে প্রকাশ করে। এটি করার মাধ্যমে, প্যারেন্ট ট্রি সেই উপাদানটি অ্যাক্সেস করতে পারে এবং ::part
উপাদান ব্যবহার করে স্টাইল করতে পারে।
যেহেতু ::part
দুটি ট্রি স্কোপকে একই উপাদান স্টাইল করার অনুমতি দেয়, তাই নিম্নোক্ত ক্যাসকেড অর্ডারটি নির্দিষ্ট করা হয়েছে:
- প্রথমে, ছায়া প্রসঙ্গের ভিতরে শৈলী পরীক্ষা করুন। এটি অংশটির "ডিফল্ট" শৈলী।
- তারপর, বাহ্যিক শৈলী প্রয়োগ করুন যেমন
::part
সংজ্ঞায়িত করা হয়েছে। এটি অংশটির "কাস্টমাইজড" শৈলী। - তারপর,
!important
এর সাথে সংজ্ঞায়িত যেকোনো অভ্যন্তরীণ শৈলী প্রয়োগ করুন। এটি একটি কাস্টম উপাদানকে ঘোষণা করতে দেয় যে একটি নির্দিষ্ট অংশের একটি নির্দিষ্ট সম্পত্তি::part
দ্বারা কাস্টমাইজযোগ্য নয়।
এর মানে হল যে ছায়া DOM-এর মধ্যে থেকে নামগুলি একটি ::part
থেকে উল্লেখ করা যাবে না, কারণ ::part
একটি ছায়া-স্কোপযুক্ত শৈলীর পরিবর্তে একটি হোস্ট-স্কোপড শৈলী। যেমন:
// inside the shadow DOM:
@keyframes fade-in {
from { opacity: 0}
}
// This shouldn't work!
// The host style shouldn't know the name "fade-in"
::part(slider) {
animation-name: fade-in;
}
নিয়ম কিভাবে ইনলাইন শৈলী সঙ্গে কাজ করা উচিত
অসদৃশ ::part
, style
অ্যাট্রিবিউট সহ ইনলাইন শৈলী, অথবা যেগুলি স্ক্রিপ্ট ব্যবহার করে প্রোগ্রাম্যাটিকভাবে স্টাইল সেট করে, সেই উপাদানটি যেখানে স্কোপ করা হয় সেখানে স্কোপ করা হয়। কারণ একটি এলিমেন্টে স্টাইল প্রয়োগ করার জন্য আপনাকে এলিমেন্ট হ্যান্ডেলে এবং এইভাবে শ্যাডো রুটে অ্যাক্সেস করতে হবে।
কিভাবে CSS নাম এবং ছায়া DOM বাস্তবে একসাথে কাজ করে
যদিও পূর্ববর্তী নিয়মগুলি সু-সংজ্ঞায়িত এবং সামঞ্জস্যপূর্ণ, বর্তমান বাস্তবায়নগুলি সর্বদা তা প্রতিফলিত করে না। অনুশীলনে, @property
ব্রাউজার জুড়ে একটি সামঞ্জস্যপূর্ণ উপায়ে স্পেক থেকে ভিন্নভাবে কাজ করে এবং অন্যান্য বৈশিষ্ট্যগুলির বেশিরভাগেরই ওপেন বাগ রয়েছে (এগুলির মধ্যে কিছু এখনও প্রকাশিত হয়নি, তাই তাদের ঠিক করার সময় আছে)।
এই বৈশিষ্ট্যগুলি অনুশীলনে কীভাবে কাজ করে তা পরীক্ষা করতে এবং প্রদর্শন করতে, আমরা নিম্নলিখিত পৃষ্ঠাটি তৈরি করেছি: https://css-names-in-the-shadow.glitch.me/ । এই পৃষ্ঠাটিতে বেশ কয়েকটি আইফ্রেম রয়েছে, প্রতিটি বৈশিষ্ট্যের একটিতে ফোকাস করে এবং ছয়টি পরিস্থিতি পরীক্ষা করে:
- একটি বাইরের নামের বাইরের রেফারেন্স : কোন ছায়া DOM জড়িত নয়, এটি কাজ করা উচিত।
- একটি অভ্যন্তরীণ নামের বাইরের রেফারেন্স : এটি কাজ করা উচিত নয়, কারণ এর অর্থ হল ছায়া প্রসঙ্গে সংজ্ঞায়িত নামটি ফাঁস হয়েছে৷
- বাইরের নামের অভ্যন্তরীণ রেফারেন্স : এটি কাজ করা উচিত, কারণ গাছের স্কোপযুক্ত নামগুলি ছায়া শিকড় দ্বারা উত্তরাধিকারসূত্রে পাওয়া যায়।
- অভ্যন্তরীণ নামের অভ্যন্তরীণ রেফারেন্স : এটি কাজ করা উচিত, কারণ রেফারেন্সের নাম উভয়ই একই সুযোগে রয়েছে।
-
::part
বাইরের নামের উল্লেখ : এটি কাজ করা উচিত, কারণ::part
এবং নাম উভয়ই একই সুযোগে ঘোষণা করা হয়েছে। -
::part
উল্লেখ : এটি কাজ করা উচিত নয়, কারণ বাইরের সুযোগটি ছায়া DOM-এর ভিতরে ঘোষিত নাম সম্পর্কে জ্ঞান অর্জন করা উচিত নয়।
@keyframes
স্পেসিফিকেশনে সংজ্ঞায়িত হিসাবে, আপনি একটি ছায়া রুটের মধ্যে থেকে কীফ্রেমের নাম উল্লেখ করতে সক্ষম হবেন, যতক্ষণ না @keyframes
at-rule পূর্বপুরুষের সুযোগে থাকে। অনুশীলনে, কোন ব্রাউজার এই আচরণটি প্রয়োগ করে না, এবং কীফ্রেম সংজ্ঞাগুলি শুধুমাত্র সেই সুযোগে উল্লেখ করা যেতে পারে যেখানে তারা সংজ্ঞায়িত করা হয়েছে। সংখ্যা 10540 দেখুন।
@property
স্পেসিফিকেশনে সংজ্ঞায়িত করা হয়েছে, @property
যেকোনো ঘোষণা নথির সুযোগে সমতল করা হবে। আজ যাইহোক, সমস্ত ব্রাউজারে আপনি ডকুমেন্টের সুযোগে শুধুমাত্র @property
ঘোষণা করতে পারেন এবং ছায়া গোড়ার মধ্যে @property
ঘোষণা উপেক্ষা করা হয়।
সংখ্যা 10541 দেখুন।
ব্রাউজার নির্দিষ্ট বাগ
অন্যান্য বৈশিষ্ট্যগুলি ব্রাউজার জুড়ে সামঞ্জস্যপূর্ণ আচরণ দেখায় না:
-
@font-face
সাফারিতে রুট স্কোপে সমতল করা হয়েছে। - Chromium একটি শ্যাডো রুটে
anchor-name
নিয়মগুলিকে উত্তরাধিকারসূত্রে নেওয়ার অনুমতি দেয় না৷ -
scroll-timeline-name
এবংview-timeline-name
::part
(এছাড়াও Chromium-এ) সঠিকভাবে স্কোপ করা হয়নি। - কোনো ব্রাউজার ছায়া শিকড়ে
@font-palette-values
ঘোষণা করার অনুমতি দেয় না। -
view-transition-class
একটি ছায়া মূলের ভিতরে সংজ্ঞায়িত করা যেতে পারে (পরিবর্তন নিজেই ছায়া-মূলের বাইরে)। - ফায়ারফক্স
::part
অভ্যন্তরীণ ছায়ার নাম (ধারক প্রশ্ন, কীফ্রেম) অ্যাক্সেস করতে দেয়। - ফায়ারফক্স এবং সাফারি ছায়ার মূলে
@counter-style
সম্মান করে না।
মনে রাখবেন counter-reset
, counter-set
, counter-increment
সামান্য ভিন্ন নিয়ম রয়েছে কারণ সেগুলি অন্তর্নিহিত নাম, এবং CSS বৈশিষ্ট্য ঘোষণা করার নিয়মগুলির একটি প্রতিষ্ঠিত এবং ভালভাবে পরীক্ষিত সেট রয়েছে।
উপসংহার
খারাপ খবর হল যে CSS নাম এবং ছায়া DOM সংক্রান্ত বর্তমান ইন্টারপ স্টেটের স্ন্যাপশট পরীক্ষা করার সময়, অভিজ্ঞতাটি অসঙ্গতিপূর্ণ এবং বগি। আমরা এখানে যে বৈশিষ্ট্যগুলি পরীক্ষা করেছি তার কোনোটিই ব্রাউজার জুড়ে এবং স্পেস অনুযায়ী ধারাবাহিকভাবে আচরণ করে না। ভাল খবর হল অভিজ্ঞতা সামঞ্জস্যপূর্ণ করতে ডেল্টা হল বাগ এবং বিশেষ সমস্যাগুলির একটি সীমিত তালিকা৷ এর এটা ঠিক করা যাক! ইতিমধ্যে, এই ওভারভিউ আশা করি সাহায্য করতে পারে যদি আপনি এই নিবন্ধে বর্ণিত অসঙ্গতির সাথে লড়াই করছেন।