একটি স্পেসিফিকেশন প্রার্থীর মাধ্যমে কোনটি চ্যাম্পিয়ন হওয়া উচিত তা নির্ধারণ করতে দুটি প্রতিযোগী বাক্য গঠনের আপনার সাহায্যের প্রয়োজন।
CSS নেস্টিং হল একটি সুবিধাজনক সিনট্যাক্স সংযোজন যা CSSকে একটি নিয়ম সেটের ভিতরে যোগ করার অনুমতি দেয়। আপনি যদি SCSS , Less বা Stylus ব্যবহার করে থাকেন, তাহলে আপনি অবশ্যই এর কয়েকটি স্বাদ দেখেছেন:
.nesting {
color: hotpink;
> .is {
color: rebeccapurple;
> .awesome {
color: deeppink;
}
}
}
যা প্রিপ্রসেসর দ্বারা নিয়মিত সিএসএসে কম্পাইল হওয়ার পরে, এটির মতো নিয়মিত সিএসএসে পরিণত হয়:
.nesting {
color: hotpink;
}
.nesting > .is {
color: rebeccapurple;
}
.nesting > .is > .awesome {
color: deeppink;
}
এই সিনট্যাক্সের একটি অফিসিয়াল CSS সংস্করণ দৃঢ়ভাবে বিবেচনা করা হচ্ছে এবং আমাদের পছন্দের মধ্যে একটি বিভাজন রয়েছে যে আমরা টাই ভাঙতে সম্প্রদায়ের সাহায্য নিযুক্ত করতে চাই। এই পোস্টের বাকি অংশে সিনট্যাক্স বিকল্পগুলি উপস্থাপন করা হবে যাতে আপনি শেষ পর্যন্ত একটি সমীক্ষা করার জন্য অবহিত বোধ করতে পারেন।
উপরে দেখানো সঠিক নেস্টিং উদাহরণ কেন CSS নেস্টিংয়ের জন্য সিনট্যাক্স হতে পারে না?
সর্বাধিক জনপ্রিয় নেস্টিং সিনট্যাক্স ব্যবহার করা যাবে না এমন কয়েকটি কারণ রয়েছে:
অস্পষ্ট পার্সিং
কিছু নেস্টেড নির্বাচক দেখতে হুবহু বৈশিষ্ট্যের মতো হতে পারে এবং প্রিপ্রসেসরগুলি বিল্ড সময়ে সমাধান করতে এবং পরিচালনা করতে সক্ষম। ব্রাউজার ইঞ্জিনে একই সামর্থ্য থাকবে না, নির্বাচকদের কখনই আলগাভাবে ব্যাখ্যা করা উচিত নয়।প্রিপ্রসেসর পার্সিং দ্বন্দ্ব
নেস্টিং এর CSS উপায় প্রিপ্রসেসর বা বিদ্যমান ডেভেলপার নেস্টিং ওয়ার্কফ্লোগুলিকে ভাঙবে না । এটি সেই বাস্তুতন্ত্র এবং সম্প্রদায়ের জন্য বিঘ্নিত এবং বিবেচনাহীন হবে।এর জন্য অপেক্ষা করছি
:is()
বেসিক নেস্টিংয়ের প্রয়োজন নেই:is()
তবে আরও জটিল নেস্টিং করে। নির্বাচক তালিকা এবং নেস্টিংয়ের হালকা ভূমিকার জন্য উদাহরণ #3 দেখুন। কল্পনা করুন যে নির্বাচক তালিকাটি শুরুতে পরিবর্তে একটি নির্বাচকের মাঝখানে ছিল, এই ক্ষেত্রে:is()
অন্য নির্বাচকের মাঝখানে নির্বাচকদের গ্রুপ করার জন্য প্রয়োজন।
আমরা কি তুলনা করছি তার সংক্ষিপ্ত বিবরণ
আমরা সিএসএস নেস্টিং সঠিকভাবে পেতে চাই, এবং সেই চেতনায় আমরা সম্প্রদায়কে অন্তর্ভুক্ত করছি। নিম্নলিখিত বিভাগগুলি আমরা যে তিনটি সম্ভাব্য সংস্করণ মূল্যায়ন করছি তা বর্ণনা করতে সাহায্য করবে৷ তারপরে আমরা তুলনা করার জন্য ব্যবহারের কিছু উদাহরণ দেখব, এবং শেষে একটি হালকা সমীক্ষা হবে যা আপনাকে জিজ্ঞাসা করবে যে আপনি সামগ্রিকভাবে কোনটি পছন্দ করেছেন৷
বিকল্প 1: @nest
এটি CSS নেস্টিং 1 -এ বর্তমান নির্দিষ্ট সিনট্যাক্স। এটি &
সাথে নতুন নেস্টেড নির্বাচকদের শুরু করে সংযুক্ত শৈলী নেস্ট করার একটি সুবিধাজনক উপায় অফার করে। এটি একটি নতুন নির্বাচকের অভ্যন্তরে যেকোনও জায়গায় &
প্রসঙ্গ রাখার উপায় হিসাবে @nest
অফার করে, যেমন আপনি যখন শুধু বিষয় যুক্ত করছেন না। এটি নমনীয় এবং ন্যূনতম কিন্তু আপনার ব্যবহারের ক্ষেত্রে @nest
বা &
উপর নির্ভর করে মনে রাখতে হবে।
বিকল্প 2: @nest সীমাবদ্ধ
এটি একটি কঠোর বিকল্প, দুটি নেস্টিং পদ্ধতি মনে রাখার জন্য উল্লিখিত খরচ কমানোর প্রয়াসে। এই সীমাবদ্ধ সিনট্যাক্সটি শুধুমাত্র @nest
অনুসরণে নেস্টিং ঘটতে দেয়, তাই শুধুমাত্র সুবিধার প্যাটার্ন যুক্ত করা নেই। পছন্দের অস্পষ্টতা দূর করা, মনে রাখার মতো একটি সহজ উপায় তৈরি করা, কিন্তু কনভেনশনের পক্ষে স্থবিরতা ত্যাগ করা।
বিকল্প 3: বন্ধনী
@nest
প্রস্তাবনার সাথে জড়িত ডবল-সিনট্যাক্স বা অতিরিক্ত বিশৃঙ্খলা এড়াতে, মিরিয়াম সুজান এবং এলিকা এটেম্যাড একটি বিকল্প সিনট্যাক্স প্রস্তাব করেছেন যা পরিবর্তে অতিরিক্ত কোঁকড়া-বন্ধনীর উপর নির্ভর করে। এটি শুধুমাত্র দুটি অতিরিক্ত অক্ষর সহ সিনট্যাক্স স্পষ্টতা প্রদান করে এবং কোন নতুন নিয়ম নেই। এটি একাধিক একইভাবে নেস্টেড নির্বাচককে সরলীকরণের উপায় হিসাবে প্রয়োজনীয় নেস্টিংয়ের ধরন অনুসারে নেস্টেড নিয়মগুলিকে গোষ্ঠীভুক্ত করার অনুমতি দেয়।
উদাহরণ 1 - সরাসরি বাসা বাঁধা
@নীড়
.foo {
color: #111;
& .bar {
color: #eee;
}
}
@নেস্ট সবসময়
.foo {
color: #111;
@nest & .bar {
color: #eee;
}
}
বন্ধনী
.foo {
color: #111;
{
& .bar {
color: #eee;
}
}
}
সমতুল্য CSS
.foo {
color: #111;
}
.foo .bar {
color: #eee;
}
উদাহরণ 2 - যৌগিক বাসা বাঁধা
@নীড়
.foo {
color: blue;
&.bar {
color: red;
}
}
@নেস্ট সবসময়
.foo {
color: blue;
@nest &.bar {
color: red;
}
}
বন্ধনী
.foo {
color: blue;
{
&.bar {
color: red;
}
}
}
সমতুল্য CSS
.foo {
color: blue;
}
.foo.bar {
color: red;
}
উদাহরণ 3 - নির্বাচক তালিকা এবং নেস্টিং
@নীড়
.foo, .bar {
color: blue;
& + .baz,
&.qux {
color: red;
}
}
@নেস্ট সবসময়
.foo, .bar {
color: blue;
@nest & + .baz,
&.qux {
color: red;
}
}
বন্ধনী
.foo, .bar {
color: blue;
{
& + .baz,
&.qux {
color: red;
}
}
}
সমতুল্য CSS
.foo, .bar {
color: blue;
}
:is(.foo, .bar) + .baz,
:is(.foo, .bar).qux {
color: red;
}
উদাহরণ 4 - একাধিক স্তর
@নীড়
figure {
margin: 0;
& > figcaption {
background: lightgray;
& > p {
font-size: .9rem;
}
}
}
@নেস্ট সবসময়
figure {
margin: 0;
@nest & > figcaption {
background: lightgray;
@nest & > p {
font-size: .9rem;
}
}
}
বন্ধনী
figure {
margin: 0;
{
& > figcaption {
background: lightgray;
{
& > p {
font-size: .9rem;
}
}
}
}
}
সমতুল্য CSS
figure {
margin: 0;
}
figure > figcaption {
background: hsl(0 0% 0% / 50%);
}
figure > figcaption > p {
font-size: .9rem;
}
উদাহরণ 5 - প্যারেন্ট নেস্টিং বা বিষয় পরিবর্তন
@নীড়
.foo {
color: red;
@nest .parent & {
color: blue;
}
}
@নেস্ট সবসময়
.foo {
color: red;
@nest .parent & {
color: blue;
}
}
বন্ধনী
.foo {
color: red;
{
.parent & {
color: blue;
}
}
}
সমতুল্য CSS
.foo {
color: red;
}
.parent .foo {
color: blue;
}
উদাহরণ 6 - সরাসরি এবং প্যারেন্ট নেস্টিং মিশ্রিত করা
@নীড়
.foo {
color: blue;
@nest .bar & {
color: red;
&.baz {
color: green;
}
}
}
@নেস্ট সবসময়
.foo {
color: blue;
@nest .bar & {
color: red;
@nest &.baz {
color: green;
}
}
}
বন্ধনী
.foo {
color: blue;
{
.bar & {
color: red;
{
&.baz {
color: green;
}
}
}
}
}
সমতুল্য CSS
.foo {
color: blue;
}
.bar .foo {
color: red;
}
.bar .foo.baz {
color: green;
}
উদাহরণ 7 - মিডিয়া কোয়েরি নেস্টিং
@নীড়
.foo {
display: grid;
@media (width => 30em) {
grid-auto-flow: column;
}
}
অথবা স্পষ্টভাবে / প্রসারিত
.foo {
display: grid;
@media (width => 30em) {
& {
grid-auto-flow: column;
}
}
}
@নেস্ট সর্বদা (সর্বদা স্পষ্ট)
.foo {
display: grid;
@media (width => 30em) {
@nest & {
grid-auto-flow: column;
}
}
}
বন্ধনী
.foo {
display: grid;
@media (width => 30em) {
grid-auto-flow: column;
}
}
অথবা স্পষ্টভাবে / প্রসারিত
.foo {
display: grid;
@media (width => 30em) {
& {
grid-auto-flow: column;
}
}
}
সমতুল্য CSS
.foo {
display: grid;
}
@media (width => 30em) {
.foo {
grid-auto-flow: column;
}
}
উদাহরণ 8 - নেস্টিং গ্রুপ
@নীড়
fieldset {
border-radius: 10px;
&:focus-within {
border-color: hotpink;
}
& > legend {
font-size: .9em;
}
& > div {
& + div {
margin-block-start: 2ch;
}
& > label {
line-height: 1.5;
}
}
}
@নেস্ট সবসময়
fieldset {
border-radius: 10px;
@nest &:focus-within {
border-color: hotpink;
}
@nest & > legend {
font-size: .9em;
}
@nest & > div {
@nest & + div {
margin-block-start: 2ch;
}
@nest & > label {
line-height: 1.5;
}
}
}
বন্ধনী
fieldset {
border-radius: 10px;
{
&:focus-within {
border-color: hotpink;
}
}
> {
legend {
font-size: .9em;
}
div {
+ div {
margin-block-start: 2ch;
}
> label {
line-height: 1.5;
}
}}
}
}
সমতুল্য CSS
fieldset {
border-radius: 10px;
}
fieldset:focus-within {
border-color: hotpink;
}
fieldset > legend {
font-size: .9em;
}
fieldset > div + div {
margin-block-start: 2ch;
}
fieldset > div > label {
line-height: 1.5;
}
উদাহরণ 9 - জটিল নেস্টিং গ্রুপ "রান্নাঘর সিঙ্ক"
@নীড়
dialog {
border: none;
&::backdrop {
backdrop-filter: blur(25px);
}
& > form {
display: grid;
& > :is(header, footer) {
align-items: flex-start;
}
}
@nest html:has(&[open]) {
overflow: hidden;
}
}
@নেস্ট সবসময়
dialog {
border: none;
@nest &::backdrop {
backdrop-filter: blur(25px);
}
@nest & > form {
display: grid;
@nest & > :is(header, footer) {
align-items: flex-start;
}
}
@nest html:has(&[open]) {
overflow: hidden;
}
}
বন্ধনী
dialog {
border: none;
{
&::backdrop {
backdrop-filter: blur(25px);
}
& > form {
display: grid;
{
& > :is(header, footer) {
align-items: flex-start;
}
}
}
}
{
html:has(&[open]) {
overflow: hidden;
}
}
}
সমতুল্য CSS
dialog {
border: none;
}
dialog::backdrop {
backdrop-filter: blur(25px);
}
dialog > form {
display: grid;
}
dialog > form > :is(header, footer) {
align-items: flex-start;
}
html:has(dialog[open]) {
overflow: hidden;
}
ভোট দেওয়ার সময়
আমরা যে সিনট্যাক্স বিকল্পগুলির মূল্যায়ন করছি তার একটি ন্যায্য তুলনা এবং নমুনা প্ল্যাটার বলে আশা করছি। দয়া করে সেগুলি সাবধানে পর্যালোচনা করুন এবং আপনি নীচে কোনটি পছন্দ করেন তা আমাদের জানান৷ সিএসএস নেস্টিংকে একটি সিনট্যাক্সে অগ্রসর করতে সাহায্য করার জন্য আমরা আপনার প্রশংসা করি আমরা সবাই জানব এবং ভালবাসব!
,একটি স্পেসিফিকেশন প্রার্থীর মাধ্যমে কোনটি চ্যাম্পিয়ন হওয়া উচিত তা নির্ধারণ করতে দুটি প্রতিযোগী বাক্য গঠনের আপনার সাহায্যের প্রয়োজন।
CSS নেস্টিং হল একটি সুবিধাজনক সিনট্যাক্স সংযোজন যা CSSকে একটি নিয়ম সেটের ভিতরে যোগ করার অনুমতি দেয়। আপনি যদি SCSS , Less বা Stylus ব্যবহার করে থাকেন, তাহলে আপনি অবশ্যই এর কয়েকটি স্বাদ দেখেছেন:
.nesting {
color: hotpink;
> .is {
color: rebeccapurple;
> .awesome {
color: deeppink;
}
}
}
যা প্রিপ্রসেসর দ্বারা নিয়মিত সিএসএসে কম্পাইল হওয়ার পরে, এটির মতো নিয়মিত সিএসএসে পরিণত হয়:
.nesting {
color: hotpink;
}
.nesting > .is {
color: rebeccapurple;
}
.nesting > .is > .awesome {
color: deeppink;
}
এই সিনট্যাক্সের একটি অফিসিয়াল CSS সংস্করণ দৃঢ়ভাবে বিবেচনা করা হচ্ছে এবং আমাদের পছন্দের মধ্যে একটি বিভাজন রয়েছে যে আমরা টাই ভাঙতে সম্প্রদায়ের সাহায্য নিযুক্ত করতে চাই। এই পোস্টের বাকি অংশে সিনট্যাক্স বিকল্পগুলি উপস্থাপন করা হবে যাতে আপনি শেষ পর্যন্ত একটি সমীক্ষা করার জন্য অবহিত বোধ করতে পারেন।
উপরে দেখানো সঠিক নেস্টিং উদাহরণ কেন CSS নেস্টিংয়ের জন্য সিনট্যাক্স হতে পারে না?
সর্বাধিক জনপ্রিয় নেস্টিং সিনট্যাক্স ব্যবহার করা যাবে না এমন কয়েকটি কারণ রয়েছে:
অস্পষ্ট পার্সিং
কিছু নেস্টেড নির্বাচক দেখতে হুবহু বৈশিষ্ট্যের মতো হতে পারে এবং প্রিপ্রসেসরগুলি বিল্ড সময়ে সমাধান করতে এবং পরিচালনা করতে সক্ষম। ব্রাউজার ইঞ্জিনে একই সামর্থ্য থাকবে না, নির্বাচকদের কখনই আলগাভাবে ব্যাখ্যা করা উচিত নয়।প্রিপ্রসেসর পার্সিং দ্বন্দ্ব
নেস্টিং এর CSS উপায় প্রিপ্রসেসর বা বিদ্যমান ডেভেলপার নেস্টিং ওয়ার্কফ্লোগুলিকে ভাঙবে না । এটি সেই বাস্তুতন্ত্র এবং সম্প্রদায়ের জন্য বিঘ্নিত এবং বিবেচনাহীন হবে।এর জন্য অপেক্ষা করছি
:is()
বেসিক নেস্টিংয়ের প্রয়োজন নেই:is()
তবে আরও জটিল নেস্টিং করে। নির্বাচক তালিকা এবং নেস্টিংয়ের হালকা ভূমিকার জন্য উদাহরণ #3 দেখুন। কল্পনা করুন যে নির্বাচক তালিকাটি শুরুতে পরিবর্তে একটি নির্বাচকের মাঝখানে ছিল, এই ক্ষেত্রে:is()
অন্য নির্বাচকের মাঝখানে নির্বাচকদের গ্রুপ করার জন্য প্রয়োজন।
আমরা কি তুলনা করছি তার সংক্ষিপ্ত বিবরণ
আমরা সিএসএস নেস্টিং সঠিকভাবে পেতে চাই, এবং সেই চেতনায় আমরা সম্প্রদায়কে অন্তর্ভুক্ত করছি। নিম্নলিখিত বিভাগগুলি আমরা যে তিনটি সম্ভাব্য সংস্করণ মূল্যায়ন করছি তা বর্ণনা করতে সাহায্য করবে৷ তারপরে আমরা তুলনা করার জন্য ব্যবহারের কিছু উদাহরণ দেখব, এবং শেষে একটি হালকা সমীক্ষা হবে যা আপনাকে জিজ্ঞাসা করবে যে আপনি সামগ্রিকভাবে কোনটি পছন্দ করেছেন৷
বিকল্প 1: @nest
এটি CSS নেস্টিং 1 -এ বর্তমান নির্দিষ্ট সিনট্যাক্স। এটি &
সাথে নতুন নেস্টেড নির্বাচকদের শুরু করে সংযুক্ত শৈলী নেস্ট করার একটি সুবিধাজনক উপায় অফার করে। এটি একটি নতুন নির্বাচকের অভ্যন্তরে যেকোনও জায়গায় &
প্রসঙ্গ রাখার উপায় হিসাবে @nest
অফার করে, যেমন আপনি যখন শুধু বিষয় যুক্ত করছেন না। এটি নমনীয় এবং ন্যূনতম কিন্তু আপনার ব্যবহারের ক্ষেত্রে @nest
বা &
উপর নির্ভর করে মনে রাখতে হবে।
বিকল্প 2: @nest সীমাবদ্ধ
এটি একটি কঠোর বিকল্প, দুটি নেস্টিং পদ্ধতি মনে রাখার জন্য উল্লিখিত খরচ কমানোর প্রয়াসে। এই সীমাবদ্ধ সিনট্যাক্সটি শুধুমাত্র @nest
অনুসরণে নেস্টিং ঘটতে দেয়, তাই শুধুমাত্র সুবিধার প্যাটার্ন যুক্ত করা নেই। পছন্দের অস্পষ্টতা দূর করা, মনে রাখার মতো একটি সহজ উপায় তৈরি করা, কিন্তু কনভেনশনের পক্ষে স্থবিরতা ত্যাগ করা।
বিকল্প 3: বন্ধনী
@nest
প্রস্তাবনার সাথে জড়িত ডবল-সিনট্যাক্স বা অতিরিক্ত বিশৃঙ্খলা এড়াতে, মিরিয়াম সুজান এবং এলিকা এটেম্যাড একটি বিকল্প সিনট্যাক্স প্রস্তাব করেছেন যা পরিবর্তে অতিরিক্ত কোঁকড়া-বন্ধনীর উপর নির্ভর করে। এটি শুধুমাত্র দুটি অতিরিক্ত অক্ষর সহ সিনট্যাক্স স্পষ্টতা প্রদান করে এবং কোন নতুন নিয়ম নেই। এটি একাধিক একইভাবে নেস্টেড নির্বাচককে সরলীকরণের উপায় হিসাবে প্রয়োজনীয় নেস্টিংয়ের ধরন অনুসারে নেস্টেড নিয়মগুলিকে গোষ্ঠীভুক্ত করার অনুমতি দেয়।
উদাহরণ 1 - সরাসরি বাসা বাঁধা
@নীড়
.foo {
color: #111;
& .bar {
color: #eee;
}
}
@নেস্ট সবসময়
.foo {
color: #111;
@nest & .bar {
color: #eee;
}
}
বন্ধনী
.foo {
color: #111;
{
& .bar {
color: #eee;
}
}
}
সমতুল্য CSS
.foo {
color: #111;
}
.foo .bar {
color: #eee;
}
উদাহরণ 2 - যৌগিক বাসা বাঁধা
@নীড়
.foo {
color: blue;
&.bar {
color: red;
}
}
@নেস্ট সবসময়
.foo {
color: blue;
@nest &.bar {
color: red;
}
}
বন্ধনী
.foo {
color: blue;
{
&.bar {
color: red;
}
}
}
সমতুল্য CSS
.foo {
color: blue;
}
.foo.bar {
color: red;
}
উদাহরণ 3 - নির্বাচক তালিকা এবং নেস্টিং
@নীড়
.foo, .bar {
color: blue;
& + .baz,
&.qux {
color: red;
}
}
@নেস্ট সবসময়
.foo, .bar {
color: blue;
@nest & + .baz,
&.qux {
color: red;
}
}
বন্ধনী
.foo, .bar {
color: blue;
{
& + .baz,
&.qux {
color: red;
}
}
}
সমতুল্য CSS
.foo, .bar {
color: blue;
}
:is(.foo, .bar) + .baz,
:is(.foo, .bar).qux {
color: red;
}
উদাহরণ 4 - একাধিক স্তর
@নীড়
figure {
margin: 0;
& > figcaption {
background: lightgray;
& > p {
font-size: .9rem;
}
}
}
@নেস্ট সবসময়
figure {
margin: 0;
@nest & > figcaption {
background: lightgray;
@nest & > p {
font-size: .9rem;
}
}
}
বন্ধনী
figure {
margin: 0;
{
& > figcaption {
background: lightgray;
{
& > p {
font-size: .9rem;
}
}
}
}
}
সমতুল্য CSS
figure {
margin: 0;
}
figure > figcaption {
background: hsl(0 0% 0% / 50%);
}
figure > figcaption > p {
font-size: .9rem;
}
উদাহরণ 5 - প্যারেন্ট নেস্টিং বা বিষয় পরিবর্তন
@নীড়
.foo {
color: red;
@nest .parent & {
color: blue;
}
}
@নেস্ট সবসময়
.foo {
color: red;
@nest .parent & {
color: blue;
}
}
বন্ধনী
.foo {
color: red;
{
.parent & {
color: blue;
}
}
}
সমতুল্য CSS
.foo {
color: red;
}
.parent .foo {
color: blue;
}
উদাহরণ 6 - সরাসরি এবং প্যারেন্ট নেস্টিং মিশ্রিত করা
@নীড়
.foo {
color: blue;
@nest .bar & {
color: red;
&.baz {
color: green;
}
}
}
@নেস্ট সবসময়
.foo {
color: blue;
@nest .bar & {
color: red;
@nest &.baz {
color: green;
}
}
}
বন্ধনী
.foo {
color: blue;
{
.bar & {
color: red;
{
&.baz {
color: green;
}
}
}
}
}
সমতুল্য CSS
.foo {
color: blue;
}
.bar .foo {
color: red;
}
.bar .foo.baz {
color: green;
}
উদাহরণ 7 - মিডিয়া কোয়েরি নেস্টিং
@নীড়
.foo {
display: grid;
@media (width => 30em) {
grid-auto-flow: column;
}
}
অথবা স্পষ্টভাবে / প্রসারিত
.foo {
display: grid;
@media (width => 30em) {
& {
grid-auto-flow: column;
}
}
}
@নেস্ট সর্বদা (সর্বদা স্পষ্ট)
.foo {
display: grid;
@media (width => 30em) {
@nest & {
grid-auto-flow: column;
}
}
}
বন্ধনী
.foo {
display: grid;
@media (width => 30em) {
grid-auto-flow: column;
}
}
অথবা স্পষ্টভাবে / প্রসারিত
.foo {
display: grid;
@media (width => 30em) {
& {
grid-auto-flow: column;
}
}
}
সমতুল্য CSS
.foo {
display: grid;
}
@media (width => 30em) {
.foo {
grid-auto-flow: column;
}
}
উদাহরণ 8 - নেস্টিং গ্রুপ
@নীড়
fieldset {
border-radius: 10px;
&:focus-within {
border-color: hotpink;
}
& > legend {
font-size: .9em;
}
& > div {
& + div {
margin-block-start: 2ch;
}
& > label {
line-height: 1.5;
}
}
}
@নেস্ট সবসময়
fieldset {
border-radius: 10px;
@nest &:focus-within {
border-color: hotpink;
}
@nest & > legend {
font-size: .9em;
}
@nest & > div {
@nest & + div {
margin-block-start: 2ch;
}
@nest & > label {
line-height: 1.5;
}
}
}
বন্ধনী
fieldset {
border-radius: 10px;
{
&:focus-within {
border-color: hotpink;
}
}
> {
legend {
font-size: .9em;
}
div {
+ div {
margin-block-start: 2ch;
}
> label {
line-height: 1.5;
}
}}
}
}
সমতুল্য CSS
fieldset {
border-radius: 10px;
}
fieldset:focus-within {
border-color: hotpink;
}
fieldset > legend {
font-size: .9em;
}
fieldset > div + div {
margin-block-start: 2ch;
}
fieldset > div > label {
line-height: 1.5;
}
উদাহরণ 9 - জটিল নেস্টিং গ্রুপ "রান্নাঘর সিঙ্ক"
@নীড়
dialog {
border: none;
&::backdrop {
backdrop-filter: blur(25px);
}
& > form {
display: grid;
& > :is(header, footer) {
align-items: flex-start;
}
}
@nest html:has(&[open]) {
overflow: hidden;
}
}
@নেস্ট সবসময়
dialog {
border: none;
@nest &::backdrop {
backdrop-filter: blur(25px);
}
@nest & > form {
display: grid;
@nest & > :is(header, footer) {
align-items: flex-start;
}
}
@nest html:has(&[open]) {
overflow: hidden;
}
}
বন্ধনী
dialog {
border: none;
{
&::backdrop {
backdrop-filter: blur(25px);
}
& > form {
display: grid;
{
& > :is(header, footer) {
align-items: flex-start;
}
}
}
}
{
html:has(&[open]) {
overflow: hidden;
}
}
}
সমতুল্য CSS
dialog {
border: none;
}
dialog::backdrop {
backdrop-filter: blur(25px);
}
dialog > form {
display: grid;
}
dialog > form > :is(header, footer) {
align-items: flex-start;
}
html:has(dialog[open]) {
overflow: hidden;
}
ভোট দেওয়ার সময়
আমরা যে সিনট্যাক্স বিকল্পগুলির মূল্যায়ন করছি তার একটি ন্যায্য তুলনা এবং নমুনা প্ল্যাটার বলে আশা করছি। দয়া করে সেগুলি সাবধানে পর্যালোচনা করুন এবং আপনি নীচে কোনটি পছন্দ করেন তা আমাদের জানান৷ সিএসএস নেস্টিংকে একটি সিনট্যাক্সে অগ্রসর করতে সাহায্য করার জন্য আমরা আপনার প্রশংসা করি আমরা সবাই জানব এবং ভালবাসব!
,একটি স্পেসিফিকেশন প্রার্থীর মাধ্যমে কোনটি চ্যাম্পিয়ন হওয়া উচিত তা নির্ধারণ করতে দুটি প্রতিযোগী বাক্য গঠনের আপনার সাহায্যের প্রয়োজন।
CSS নেস্টিং হল একটি সুবিধাজনক সিনট্যাক্স সংযোজন যা CSSকে একটি নিয়ম সেটের ভিতরে যোগ করার অনুমতি দেয়। আপনি যদি SCSS , Less বা Stylus ব্যবহার করে থাকেন, তাহলে আপনি অবশ্যই এর কয়েকটি স্বাদ দেখেছেন:
.nesting {
color: hotpink;
> .is {
color: rebeccapurple;
> .awesome {
color: deeppink;
}
}
}
যা প্রিপ্রসেসর দ্বারা নিয়মিত সিএসএসে কম্পাইল হওয়ার পরে, এটির মতো নিয়মিত সিএসএসে পরিণত হয়:
.nesting {
color: hotpink;
}
.nesting > .is {
color: rebeccapurple;
}
.nesting > .is > .awesome {
color: deeppink;
}
এই সিনট্যাক্সের একটি অফিসিয়াল CSS সংস্করণ দৃঢ়ভাবে বিবেচনা করা হচ্ছে এবং আমাদের পছন্দের মধ্যে একটি বিভাজন রয়েছে যে আমরা টাই ভাঙতে সম্প্রদায়ের সাহায্য নিযুক্ত করতে চাই। এই পোস্টের বাকি অংশে সিনট্যাক্স বিকল্পগুলি উপস্থাপন করা হবে যাতে আপনি শেষ পর্যন্ত একটি সমীক্ষা করার জন্য অবহিত বোধ করতে পারেন।
উপরে দেখানো সঠিক নেস্টিং উদাহরণ কেন CSS নেস্টিংয়ের জন্য সিনট্যাক্স হতে পারে না?
সর্বাধিক জনপ্রিয় নেস্টিং সিনট্যাক্স ব্যবহার করা যাবে না এমন কয়েকটি কারণ রয়েছে:
অস্পষ্ট পার্সিং
কিছু নেস্টেড নির্বাচক দেখতে হুবহু বৈশিষ্ট্যের মতো হতে পারে এবং প্রিপ্রসেসরগুলি বিল্ড সময়ে সমাধান করতে এবং পরিচালনা করতে সক্ষম। ব্রাউজার ইঞ্জিনে একই সামর্থ্য থাকবে না, নির্বাচকদের কখনই আলগাভাবে ব্যাখ্যা করা উচিত নয়।প্রিপ্রসেসর পার্সিং দ্বন্দ্ব
নেস্টিং এর CSS উপায় প্রিপ্রসেসর বা বিদ্যমান ডেভেলপার নেস্টিং ওয়ার্কফ্লোগুলিকে ভাঙবে না । এটি সেই বাস্তুতন্ত্র এবং সম্প্রদায়ের জন্য বিঘ্নিত এবং বিবেচনাহীন হবে।এর জন্য অপেক্ষা করছি
:is()
বেসিক নেস্টিংয়ের প্রয়োজন নেই:is()
তবে আরও জটিল নেস্টিং করে। নির্বাচক তালিকা এবং নেস্টিংয়ের হালকা ভূমিকার জন্য উদাহরণ #3 দেখুন। কল্পনা করুন যে নির্বাচক তালিকাটি শুরুতে পরিবর্তে একটি নির্বাচকের মাঝখানে ছিল, এই ক্ষেত্রে:is()
অন্য নির্বাচকের মাঝখানে নির্বাচকদের গ্রুপ করার জন্য প্রয়োজন।
আমরা কি তুলনা করছি তার সংক্ষিপ্ত বিবরণ
আমরা সিএসএস নেস্টিং সঠিকভাবে পেতে চাই, এবং সেই চেতনায় আমরা সম্প্রদায়কে অন্তর্ভুক্ত করছি। নিম্নলিখিত বিভাগগুলি আমরা যে তিনটি সম্ভাব্য সংস্করণ মূল্যায়ন করছি তা বর্ণনা করতে সাহায্য করবে৷ তারপরে আমরা তুলনা করার জন্য ব্যবহারের কিছু উদাহরণ দেখব, এবং শেষে একটি হালকা সমীক্ষা হবে যা আপনাকে জিজ্ঞাসা করবে যে আপনি সামগ্রিকভাবে কোনটি পছন্দ করেছেন৷
বিকল্প 1: @nest
এটি CSS নেস্টিং 1 -এ বর্তমান নির্দিষ্ট সিনট্যাক্স। এটি &
সাথে নতুন নেস্টেড নির্বাচকদের শুরু করে সংযুক্ত শৈলী নেস্ট করার একটি সুবিধাজনক উপায় অফার করে। এটি একটি নতুন নির্বাচকের অভ্যন্তরে যেকোনও জায়গায় &
প্রসঙ্গ রাখার উপায় হিসাবে @nest
অফার করে, যেমন আপনি যখন শুধু বিষয় যুক্ত করছেন না। এটি নমনীয় এবং ন্যূনতম কিন্তু আপনার ব্যবহারের ক্ষেত্রে @nest
বা &
উপর নির্ভর করে মনে রাখতে হবে।
বিকল্প 2: @nest সীমাবদ্ধ
এটি একটি কঠোর বিকল্প, দুটি নেস্টিং পদ্ধতি মনে রাখার জন্য উল্লিখিত খরচ কমানোর প্রয়াসে। এই সীমাবদ্ধ সিনট্যাক্সটি শুধুমাত্র @nest
অনুসরণে নেস্টিং ঘটতে দেয়, তাই শুধুমাত্র সুবিধার প্যাটার্ন যুক্ত করা নেই। পছন্দের অস্পষ্টতা দূর করা, মনে রাখার মতো একটি সহজ উপায় তৈরি করা, কিন্তু কনভেনশনের পক্ষে স্থবিরতা ত্যাগ করা।
বিকল্প 3: বন্ধনী
@nest
প্রস্তাবনার সাথে জড়িত ডবল-সিনট্যাক্স বা অতিরিক্ত বিশৃঙ্খলা এড়াতে, মিরিয়াম সুজান এবং এলিকা এটেম্যাড একটি বিকল্প সিনট্যাক্স প্রস্তাব করেছেন যা পরিবর্তে অতিরিক্ত কোঁকড়া-বন্ধনীর উপর নির্ভর করে। এটি শুধুমাত্র দুটি অতিরিক্ত অক্ষর সহ সিনট্যাক্স স্পষ্টতা প্রদান করে এবং কোন নতুন নিয়ম নেই। এটি একাধিক একইভাবে নেস্টেড নির্বাচককে সরলীকরণের উপায় হিসাবে প্রয়োজনীয় নেস্টিংয়ের ধরন অনুসারে নেস্টেড নিয়মগুলিকে গোষ্ঠীভুক্ত করার অনুমতি দেয়।
উদাহরণ 1 - সরাসরি বাসা বাঁধা
@নীড়
.foo {
color: #111;
& .bar {
color: #eee;
}
}
@নেস্ট সবসময়
.foo {
color: #111;
@nest & .bar {
color: #eee;
}
}
বন্ধনী
.foo {
color: #111;
{
& .bar {
color: #eee;
}
}
}
সমতুল্য CSS
.foo {
color: #111;
}
.foo .bar {
color: #eee;
}
উদাহরণ 2 - যৌগিক বাসা বাঁধা
@নীড়
.foo {
color: blue;
&.bar {
color: red;
}
}
@নেস্ট সবসময়
.foo {
color: blue;
@nest &.bar {
color: red;
}
}
বন্ধনী
.foo {
color: blue;
{
&.bar {
color: red;
}
}
}
সমতুল্য CSS
.foo {
color: blue;
}
.foo.bar {
color: red;
}
উদাহরণ 3 - নির্বাচক তালিকা এবং নেস্টিং
@নীড়
.foo, .bar {
color: blue;
& + .baz,
&.qux {
color: red;
}
}
@নেস্ট সবসময়
.foo, .bar {
color: blue;
@nest & + .baz,
&.qux {
color: red;
}
}
বন্ধনী
.foo, .bar {
color: blue;
{
& + .baz,
&.qux {
color: red;
}
}
}
সমতুল্য CSS
.foo, .bar {
color: blue;
}
:is(.foo, .bar) + .baz,
:is(.foo, .bar).qux {
color: red;
}
উদাহরণ 4 - একাধিক স্তর
@নীড়
figure {
margin: 0;
& > figcaption {
background: lightgray;
& > p {
font-size: .9rem;
}
}
}
@নেস্ট সবসময়
figure {
margin: 0;
@nest & > figcaption {
background: lightgray;
@nest & > p {
font-size: .9rem;
}
}
}
বন্ধনী
figure {
margin: 0;
{
& > figcaption {
background: lightgray;
{
& > p {
font-size: .9rem;
}
}
}
}
}
সমতুল্য CSS
figure {
margin: 0;
}
figure > figcaption {
background: hsl(0 0% 0% / 50%);
}
figure > figcaption > p {
font-size: .9rem;
}
উদাহরণ 5 - প্যারেন্ট নেস্টিং বা বিষয় পরিবর্তন
@নীড়
.foo {
color: red;
@nest .parent & {
color: blue;
}
}
@নেস্ট সবসময়
.foo {
color: red;
@nest .parent & {
color: blue;
}
}
বন্ধনী
.foo {
color: red;
{
.parent & {
color: blue;
}
}
}
সমতুল্য CSS
.foo {
color: red;
}
.parent .foo {
color: blue;
}
উদাহরণ 6 - সরাসরি এবং প্যারেন্ট নেস্টিং মিশ্রিত করা
@নীড়
.foo {
color: blue;
@nest .bar & {
color: red;
&.baz {
color: green;
}
}
}
@নেস্ট সবসময়
.foo {
color: blue;
@nest .bar & {
color: red;
@nest &.baz {
color: green;
}
}
}
বন্ধনী
.foo {
color: blue;
{
.bar & {
color: red;
{
&.baz {
color: green;
}
}
}
}
}
সমতুল্য CSS
.foo {
color: blue;
}
.bar .foo {
color: red;
}
.bar .foo.baz {
color: green;
}
উদাহরণ 7 - মিডিয়া কোয়েরি নেস্টিং
@নীড়
.foo {
display: grid;
@media (width => 30em) {
grid-auto-flow: column;
}
}
অথবা স্পষ্টভাবে / প্রসারিত
.foo {
display: grid;
@media (width => 30em) {
& {
grid-auto-flow: column;
}
}
}
@নেস্ট সর্বদা (সর্বদা স্পষ্ট)
.foo {
display: grid;
@media (width => 30em) {
@nest & {
grid-auto-flow: column;
}
}
}
বন্ধনী
.foo {
display: grid;
@media (width => 30em) {
grid-auto-flow: column;
}
}
অথবা স্পষ্টভাবে / প্রসারিত
.foo {
display: grid;
@media (width => 30em) {
& {
grid-auto-flow: column;
}
}
}
সমতুল্য CSS
.foo {
display: grid;
}
@media (width => 30em) {
.foo {
grid-auto-flow: column;
}
}
উদাহরণ 8 - নেস্টিং গ্রুপ
@নীড়
fieldset {
border-radius: 10px;
&:focus-within {
border-color: hotpink;
}
& > legend {
font-size: .9em;
}
& > div {
& + div {
margin-block-start: 2ch;
}
& > label {
line-height: 1.5;
}
}
}
@নেস্ট সবসময়
fieldset {
border-radius: 10px;
@nest &:focus-within {
border-color: hotpink;
}
@nest & > legend {
font-size: .9em;
}
@nest & > div {
@nest & + div {
margin-block-start: 2ch;
}
@nest & > label {
line-height: 1.5;
}
}
}
বন্ধনী
fieldset {
border-radius: 10px;
{
&:focus-within {
border-color: hotpink;
}
}
> {
legend {
font-size: .9em;
}
div {
+ div {
margin-block-start: 2ch;
}
> label {
line-height: 1.5;
}
}}
}
}
সমতুল্য CSS
fieldset {
border-radius: 10px;
}
fieldset:focus-within {
border-color: hotpink;
}
fieldset > legend {
font-size: .9em;
}
fieldset > div + div {
margin-block-start: 2ch;
}
fieldset > div > label {
line-height: 1.5;
}
উদাহরণ 9 - জটিল নেস্টিং গ্রুপ "রান্নাঘর সিঙ্ক"
@নীড়
dialog {
border: none;
&::backdrop {
backdrop-filter: blur(25px);
}
& > form {
display: grid;
& > :is(header, footer) {
align-items: flex-start;
}
}
@nest html:has(&[open]) {
overflow: hidden;
}
}
@নেস্ট সবসময়
dialog {
border: none;
@nest &::backdrop {
backdrop-filter: blur(25px);
}
@nest & > form {
display: grid;
@nest & > :is(header, footer) {
align-items: flex-start;
}
}
@nest html:has(&[open]) {
overflow: hidden;
}
}
বন্ধনী
dialog {
border: none;
{
&::backdrop {
backdrop-filter: blur(25px);
}
& > form {
display: grid;
{
& > :is(header, footer) {
align-items: flex-start;
}
}
}
}
{
html:has(&[open]) {
overflow: hidden;
}
}
}
সমতুল্য CSS
dialog {
border: none;
}
dialog::backdrop {
backdrop-filter: blur(25px);
}
dialog > form {
display: grid;
}
dialog > form > :is(header, footer) {
align-items: flex-start;
}
html:has(dialog[open]) {
overflow: hidden;
}
ভোট দেওয়ার সময়
আমরা যে সিনট্যাক্স বিকল্পগুলির মূল্যায়ন করছি তার একটি ন্যায্য তুলনা এবং নমুনা প্ল্যাটার বলে আশা করছি। দয়া করে সেগুলি সাবধানে পর্যালোচনা করুন এবং আপনি নীচে কোনটি পছন্দ করেন তা আমাদের জানান৷ সিএসএস নেস্টিংকে একটি সিনট্যাক্সে অগ্রসর করতে সাহায্য করার জন্য আমরা আপনার প্রশংসা করি আমরা সবাই জানব এবং ভালবাসব!