ক্যাসকেড স্তরগুলি আপনার ব্রাউজারে আসছে৷

ক্যাসকেড স্তর ( @layer CSS নিয়ম ) Chromium 99, Firefox 97, এবং Safari 15.4 বিটাতে আসছে। শৈলী-নির্দিষ্টতা দ্বন্দ্ব প্রতিরোধ করতে তারা আপনার CSS ফাইলগুলির আরও স্পষ্ট নিয়ন্ত্রণ সক্ষম করে। এটি বিশেষ করে বড় কোডবেস, ডিজাইন সিস্টেম এবং অ্যাপ্লিকেশনগুলিতে তৃতীয় পক্ষের শৈলী পরিচালনা করার জন্য দরকারী।

একটি পরিষ্কার উপায়ে আপনার CSS লেয়ারিং অপ্রত্যাশিত শৈলী ওভাররাইড প্রতিরোধ করে এবং উন্নত CSS আর্কিটেকচার প্রচার করে।

CSS নির্দিষ্টতা এবং ক্যাসকেড

CSS নির্দিষ্টতা হল কিভাবে CSS সিদ্ধান্ত নেয় কোন স্টাইল কোন উপাদানে প্রয়োগ করতে হবে। আপনি ব্যবহার করতে পারেন বিভিন্ন নির্বাচক যে কোনো শৈলী নিয়ম নির্দিষ্টতা নির্ধারণ. উদাহরণস্বরূপ, উপাদানগুলি ক্লাস বা বৈশিষ্ট্যগুলির তুলনায় কম নির্দিষ্ট, যা আইডিগুলির তুলনায় কম নির্দিষ্ট। এটি সিএসএস শেখার একটি প্রাথমিক অংশ।

লোকেরা অনিচ্ছাকৃতভাবে নির্দিষ্টতাকে ওভাররাইডিং প্রতিরোধ করতে BEM-এর মতো CSS নামকরণের রীতিতে ফিরে যায়। সবকিছুকে একটি একক শ্রেণিনাম দিয়ে, সবকিছু একই নির্দিষ্টতার সমতলে স্থাপন করা হয়। যাইহোক, এই ধরনের সংগঠিত শৈলী বজায় রাখা সবসময় সম্ভব নয়, বিশেষ করে যখন তৃতীয় পক্ষের কোড এবং ডিজাইন সিস্টেমের সাথে কাজ করা হয়।

ক্লাস সহ একটি কার্ডের BEM ভিজ্যুয়াল
keepinguptodate.com থেকে BEM নামকরণের একটি সচিত্র উদাহরণ।

ক্যাসকেড স্তরগুলি এই সমস্যাটি সমাধান করার লক্ষ্য রাখে। তারা CSS ক্যাসকেডে একটি নতুন স্তর প্রবর্তন করে। স্তরযুক্ত শৈলীর সাথে, একটি স্তরের অগ্রাধিকার সর্বদা একটি নির্বাচকের নির্দিষ্টতাকে হারায়।

উদাহরণস্বরূপ, নির্বাচক .post a.link .card a এর চেয়ে উচ্চতর নির্দিষ্টতা রয়েছে। একটি লিঙ্ক স্টাইল করার চেষ্টা করলে, একটি কার্ডের ভিতরে, একটি পোস্টের মধ্যে আপনি দেখতে পাবেন যে আরও নির্দিষ্ট নির্বাচক প্রয়োগ করা হবে।

@layer ব্যবহার করে, আপনি প্রতিটির শৈলী-নির্দিষ্টতা সম্পর্কে আরও স্পষ্ট হতে পারেন এবং নিশ্চিত করুন যে আপনার কার্ড লিঙ্কের শৈলীগুলি পোস্ট লিঙ্কের শৈলীগুলিকে ওভাররাইড করে, যদিও আপনার সমস্ত CSS একই প্লেনে থাকলে নির্দিষ্টতা সংখ্যাগতভাবে কম হতে পারে। এটি ক্যাসকেড প্রাধান্যের কারণে। স্তরযুক্ত শৈলী নতুন ক্যাসকেড "প্লেন" তৈরি করে।

ব্রেক আউট UI প্রকল্পের ডেমো থেকে দৃষ্টান্ত

@layer ইন অ্যাকশন

ডেমো আমদানির সাথে লিঙ্কের রঙ দেখাচ্ছে
কোডপেনে ডেমো দেখুন।

এই উদাহরণটি @layer ব্যবহার করে ক্যাসকেড স্তরগুলির শক্তি প্রদর্শন করে। এখানে বেশ কয়েকটি লিঙ্ক দেখানো হয়েছে: কিছু অতিরিক্ত ক্লাসের নাম ছাড়াই প্রয়োগ করা হয়েছে, একটি .link ক্লাস সহ এবং একটি .pink ক্লাস সহ। CSS তারপর তিনটি স্তর যুক্ত করে: base , typography এবং utilities নিম্নরূপ:

@layer base {
  a {
    font-weight: 800;
    color: red; /* ignored */
  }

  .link {
    color: blue; /* ignored */
  }
}

@layer typography {
  a {
    color: green; /* styles *all* links */
  }
}

@layer utilities {
  .pink {
    color: hotpink;  /* styles *all* .pink's */
  }
}

শেষ পর্যন্ত, সমস্ত লিঙ্ক হয় সবুজ বা গোলাপী। এর কারণ হল: যেখানে .link a তুলনায় একটি উচ্চতর নির্বাচক-স্তরের নির্দিষ্টতা রয়েছে, সেখানে a উচ্চতর অগ্রাধিকারে @layer একটি রঙ শৈলী রয়েছে। a { color: green } ওভাররাইড করে .link { color: blue } যখন নীল নিয়মের পরে সবুজ নিয়মটি একটি স্তরে থাকে।

স্তর অগ্রাধিকার উপাদান নির্দিষ্টতা বীট.

স্তর সংগঠিত

উপরে দেখানো হিসাবে আপনি সরাসরি পৃষ্ঠায় স্তরগুলি সংগঠিত করতে পারেন, অথবা আপনি একটি ফাইলের শীর্ষে তাদের সংগঠিত করতে পারেন।

আপনার কোডে প্রতিটি স্তরের নাম প্রথমবার প্রদর্শিত হলে স্তরের ক্রম প্রতিষ্ঠিত হয়।

তার মানে, আপনি যদি ফাইলের উপরের অংশে নিম্নলিখিতগুলি যোগ করেন, লিঙ্কগুলি সমস্ত লাল দেখাবে এবং ক্লাস .link এর সাথে লিঙ্কটি নীল দেখাবে:

@layer utilities, typography, base;

এর কারণ হল লেয়ার অর্ডারটি এখন উল্টে গেছে, ইউটিলিটিগুলিকে প্রথমে এবং বেসকে শেষ করে। তাই, base লেয়ারের শৈলীর নিয়মগুলি সবসময় টাইপোগ্রাফি স্তরের শৈলীর নিয়মগুলির চেয়ে উচ্চতর নির্দিষ্টতা থাকবে। তারা আর সবুজ লিঙ্ক হতে যাচ্ছে না, কিন্তু পরিবর্তে লাল বা নীল.

কোডপেন প্রকল্পের স্ক্রিনশট
কোডপেনে ডেমো দেখুন।

আমদানি আয়োজন

@layer ব্যবহার করার আরেকটি উপায় হল আমদানি ফাইল। নিম্নলিখিত উদাহরণের মতো একটি layer() ফাংশন ব্যবহার করে আপনি শৈলী আমদানি করার সময় আপনি সরাসরি এটি করতে পারেন:

/* Base */
@import '../styles/base/normalize.css' layer(base); /* normalize or rest file */
@import '../styles/base/base.css' layer(base); /* body and base styles */
@import '../styles/base/theme.css' layer(theme); /* theme variables */
@import '../styles/base/typography.css' layer(theme); /* theme typography */
@import '../styles/base/utilities.css' layer(utilities); /* base utilities */

/* Layouts */
@import '../styles/components/post.css' layer(layouts); /* post layout */

/* Components */
@import '../styles/components/cards.css' layer(components); /* imports card */
@import '../styles/components/footer.css' layer(components); /* footer component */

উপরের কোড স্নিপেটে তিনটি স্তর রয়েছে: base , layouts এবং components । সাধারণীকরণ, থিম, এবং টাইপোগ্রাফি ফাইলগুলিকে base , layouts একটি post ফাইল সহ, এবং cards এবং footer উভয় components । ফাইল আমদানি করার সময়, স্তর ফাংশন ব্যবহার করে স্তরগুলিকে তাত্ক্ষণিক করা হয়। একটি বিকল্প পদ্ধতি হল ফাইলের শীর্ষে আপনার স্তরগুলিকে সংগঠিত করা, কোনো আমদানির আগে সেগুলি ঘোষণা করা:

@layer base,
       theme,
       layouts,
       components,
       utilities;

এখন, আপনি যে ক্রমানুসারে আপনার শৈলীগুলিকে @import তাতে লেয়ার অর্ডারের কোন ব্যাপার নেই, যেহেতু এটি ইতিমধ্যেই লেয়ার নামের প্রথম উদাহরণে প্রতিষ্ঠিত হয়েছে। এটি সম্পর্কে চিন্তা করার জন্য একটি কম জিনিস. আপনি এখনও নির্দিষ্ট স্তরে আমদানি করা ফাইল সেট করতে পারেন, কিন্তু অর্ডার ইতিমধ্যেই প্রতিষ্ঠিত।

কোডপেন প্রজেক্ট থেকে স্ক্রিনশট
কোডপেন প্রকল্পটি অন্বেষণ করুন।

স্তর এবং ক্যাসকেড

আসুন একধাপ পিছিয়ে যাই এবং দেখি কোথায় স্তরগুলি ব্যবহার করা হয়েছে কারণ এটি বিস্তৃত ক্যাসকেডের সাথে সম্পর্কিত:

ক্যাসকেড ইলাস্ট্রেশন

অগ্রাধিকারের ক্রমটি এমন:

  • ব্যবহারকারী এজেন্ট স্বাভাবিক (সর্বনিম্ন অগ্রাধিকার)
  • স্থানীয় ব্যবহারকারী @layer
  • স্থানীয় ব্যবহারকারী স্বাভাবিক
  • লেখক @layers
  • লেখক স্বাভাবিক
  • লেখক !গুরুত্বপূর্ণ
  • লেখক @layer !গুরুত্বপূর্ণ
  • স্থানীয় ব্যবহারকারী !গুরুত্বপূর্ণ৷
  • ব্যবহারকারী এজেন্ট! গুরুত্বপূর্ণ** (সর্বোচ্চ অগ্রাধিকার)

আপনি এখানে লক্ষ্য করতে পারেন যে @layer !important শৈলী উল্টানো হয়েছে। অ-স্তরবিশিষ্ট (স্বাভাবিক) শৈলীগুলির তুলনায় কম নির্দিষ্ট হওয়ার পরিবর্তে, তাদের উচ্চতর অগ্রাধিকার রয়েছে। ক্যাসকেডে কীভাবে কাজ করে তা !important : এটি আপনার স্টাইলশীটগুলিতে স্বাভাবিক ক্যাসকেডিং ভেঙে দেয় এবং সাধারণ স্তর-স্তরের নির্দিষ্টতা (অগ্রাধিকার) বিপরীত করে।

নেস্টেড স্তর

স্তরগুলি অন্যান্য স্তরগুলির মধ্যেও নেস্ট করা যেতে পারে। নিম্নলিখিত উদাহরণটি মরিয়ম সুজানের ক্যাসকেড লেয়ার ব্যাখ্যাকারী থেকে এসেছে:

@layer default {
  p { max-width: 70ch; }
}

@layer framework {
  @layer default {
    p { margin-block: 0.75em; }
  }

  p { margin-bottom: 1em; }
}

উপরের কোড স্নিপেটে, আপনি একটি ব্যবহার করে framework.default অ্যাক্সেস করতে পারেন . framework মধ্যে default স্তরটি নেস্ট করার একটি সংকেত হিসাবে। আপনি আরও শর্টহ্যান্ড বিন্যাসে এটি লিখতে পারেন:

@layer framework.default {
  p { margin-block: 0.75em }
}

ফলস্বরূপ স্তর এবং স্তর-ক্রম হল:

  • ডিফল্ট
  • framework.default
  • framework unlayered
  • স্তরবিহীন

জিনিসের জন্য আউট তাকান

ক্যাসকেড স্তরগুলি যদি আপনি সঠিকভাবে ব্যবহার করেন তবে এটি দুর্দান্ত হতে পারে তবে তারা অতিরিক্ত বিভ্রান্তি এবং অপ্রত্যাশিত ফলাফলও তৈরি করতে পারে। ক্যাসকেড স্তরগুলির সাথে কাজ করার সময় নিম্নলিখিতগুলির জন্য দেখুন:

নিয়ম 1: স্কোপিংয়ের জন্য @layer ব্যবহার করবেন না

ক্যাসকেড স্তরগুলি স্কোপিংয়ের সমাধান করে না। আপনার যদি @layer সহ একটি CSS ফাইল থাকে, তাহলে card.css বলুন এবং কার্ডের মধ্যে থাকা সমস্ত লিঙ্ককে স্টাইল করতে চান, এই ধরনের স্টাইল লিখবেন না:

a {
  …
}

এটি আপনার ফাইলের সমস্ত a এই ওভাররাইডের দিকে নিয়ে যাবে। আপনার শৈলীগুলি সঠিকভাবে স্কোপ করা এখনও গুরুত্বপূর্ণ:

.card a {
  …
}

নিয়ম 2: ক্যাসকেড স্তরগুলি অ-স্তরবিহীন CSS এর পিছনে অর্ডার করা হয়

এটা মনে রাখা গুরুত্বপূর্ণ যে একটি স্তরযুক্ত CSS ফাইল অ-স্তরযুক্ত CSS ওভাররাইড করবে না । আপনার বিদ্যমান কোডবেসের সাথে কাজ করার জন্য আরও বুদ্ধিমান উপায়ে স্তরগুলি প্রবর্তন করা সহজ করার জন্য এটি একটি ইচ্ছাকৃত সিদ্ধান্ত ছিল। একটি reset.css ফাইল ব্যবহার করা, উদাহরণস্বরূপ, ক্যাসকেড স্তরগুলির জন্য একটি ভাল সূচনা এবং ব্যবহার কেস।

নিয়ম 3: !important ক্যাসকেড নির্দিষ্টতা উল্টে দেয়

যদিও স্তরযুক্ত শৈলীগুলি সাধারণভাবে অস্তরবিহীন শৈলীগুলির চেয়ে কম নির্দিষ্ট, !important ব্যবহার করে এটিকে বিপরীত করে৷ একটি স্তরে, !important নিয়মের সাথে ঘোষণাগুলি স্তরবিহীন শৈলীগুলির চেয়ে আরও নির্দিষ্ট।

সেই ক্ষেত্রে, !important শৈলীগুলি তাদের নির্দিষ্টতাকে উল্টে দেয়। উপরের চিত্রটি রেফারেন্সের জন্য এটি দেখায়: লেখক @layers-এর লেখক স্বাভাবিকের তুলনায় কম অগ্রাধিকার রয়েছে যার লেখকের চেয়ে কম অগ্রাধিকার রয়েছে! গুরুত্বপূর্ণ যার লেখক @layer থেকে কম অগ্রাধিকার রয়েছে! গুরুত্বপূর্ণ।

আপনার যদি একাধিক স্তর থাকে, !important এর সাথে প্রথম স্তরটি !important অগ্রাধিকার নেবে এবং সবচেয়ে নির্দিষ্ট শৈলী হবে৷

নিয়ম 4: ইনজেকশন পয়েন্ট বুঝুন

যেহেতু লেয়ার অর্ডারটি প্রথমবার আপনার কোডে প্রতিটি লেয়ারের নাম প্রদর্শিত হওয়ার দ্বারা প্রতিষ্ঠিত হয়, আপনি যদি layer() এর আমদানি এবং সেট করার পরে বা একটি ভিন্ন @layer স্টেটমেন্টের পরে একটি @layer ঘোষণা দেন, তাহলে এটি উপেক্ষা করা যেতে পারে। CSS-এর বিপরীতে, যেখানে পৃষ্ঠার সবচেয়ে দূরবর্তী শৈলী নিয়মটি ক্যাসকেড স্তরগুলির জন্য প্রয়োগ করা হয়, প্রথম উদাহরণে ক্রম প্রতিষ্ঠিত হয়।

এটি একটি তালিকায়, একটি স্তর ব্লকে বা একটি আমদানিতে হতে পারে। আপনি যদি layer() এর সাথে একটি আমদানি তালিকার পরে @layer রাখেন তবে এটি কিছুই করবে না। এটিকে ফাইলের শীর্ষে রাখলে এটি স্তরের ক্রম সেট করবে এবং আর্কিটেকচারের মধ্যে স্তরগুলিকে স্পষ্টভাবে দেখতে আপনাকে সহায়তা করবে।

নিয়ম #5: আপনার নির্দিষ্টতা দেখুন

ক্যাসকেড স্তরগুলির সাথে, একটি কম-নির্দিষ্ট নির্বাচক (যেমন a ) একটি আরও-নির্দিষ্ট নির্বাচককে (যেমন .link ) ওভাররাইড করবে যদি সেই কম-নির্দিষ্ট নির্বাচকটি আরও নির্দিষ্ট স্তরে থাকে। নিম্নোক্ত বিবেচনা কর:

a ইন layer(components) .pink ইন layer(utilities) ওভাররাইড করবে যদি: @layer utilities, components নির্দিষ্ট করা হয়। API এর একটি ইচ্ছাকৃত অংশ হলেও, আপনি যদি এটি আশা না করেন তবে এটি বিভ্রান্তিকর এবং হতাশাজনক হতে পারে।

তাই আপনি যদি ইউটিলিটি ক্লাস লিখছেন, আপনি যে উপাদানগুলির সাথে ওভাররাইড করতে চান তার চেয়ে সর্বদা সেগুলিকে একটি উচ্চ-ক্রম স্তর হিসাবে অন্তর্ভুক্ত করুন৷ আপনি ভাবতে পারেন "আমি রঙ পরিবর্তন করার জন্য এই .pink ক্লাসটি যোগ করেছি এবং এটি প্রয়োগ করা হচ্ছে না"।

ক্যাসকেড স্তর সম্পর্কে আরও জানুন

ক্যাসকেড স্তরগুলি সম্পর্কে আরও জানতে আপনি এই সংস্থানগুলিও পরীক্ষা করে দেখতে পারেন: