CSS গাঁথনি জন্য একটি বিকল্প প্রস্তাব

ক্রোম টিম ওয়েবে রাজমিস্ত্রির ধরণের লেআউটগুলির বাস্তবায়ন দেখতে আগ্রহী৷ যাইহোক, আমরা মনে করি যে সাম্প্রতিক ওয়েবকিট পোস্টে প্রস্তাবিত CSS গ্রিড স্পেসিফিকেশনের অংশ হিসাবে এটি বাস্তবায়ন করা একটি ভুল হবে। আমরা আরও মনে করি যে WebKit পোস্টটি রাজমিস্ত্রির এমন একটি সংস্করণের বিরুদ্ধে যুক্তি দিয়েছে যা কেউ প্রস্তাব করছে না।

তাই, এই পোস্টের উদ্দেশ্য ব্যাখ্যা করা যে কেন আমরা ক্রোমে CSS গ্রিড লেআউট স্পেসিফিকেশনের অংশ হিসাবে রাজমিস্ত্রি বাস্তবায়নের বিষয়ে উদ্বেগ প্রকাশ করি এবং বিকল্প প্রস্তাবটি কী সক্ষম করে তা স্পষ্ট করে। সংক্ষেপে:

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

রাজমিস্ত্রি গ্রিডের অংশ হওয়া উচিত?

ক্রোম টিম বিশ্বাস করে যে রাজমিস্ত্রি একটি পৃথক বিন্যাস পদ্ধতি হওয়া উচিত, যা display: masonry (অথবা অন্য একটি কীওয়ার্ডের উপর একটি ভাল নাম নির্ধারণ করা উচিত)। পরে এই পোস্টে, আপনি কোডে দেখতে কেমন হতে পারে তার কিছু উদাহরণ দেখতে পারেন।

দুটি সম্পর্কিত কারণ রয়েছে কেন আমরা মনে করি যে রাজমিস্ত্রি গ্রিড বিন্যাসের বাইরে আরও ভালভাবে সংজ্ঞায়িত করা হয়েছে—লেআউট পারফরম্যান্স সমস্যার সম্ভাব্যতা, এবং সত্য যে রাজমিস্ত্রি এবং গ্রিড উভয়ের বৈশিষ্ট্য রয়েছে যা একটি লেআউট পদ্ধতিতে বোঝা যায় কিন্তু অন্যটিতে নয়।

কর্মক্ষমতা

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

অতএব, আপনার যদি grid-template-columns: 200px auto 200px — গ্রিডে করা একটি খুব সাধারণ জিনিস—আপনি সমস্যায় পড়তে শুরু করেন। আপনি একবার সাবগ্রিড যোগ করলে এই সমস্যাগুলি সূচকীয় হয়ে ওঠে

একটি যুক্তি রয়েছে যে বেশিরভাগ লোকেরা এটির সাথে জড়িত হবে না, তবে আমরা ইতিমধ্যে জানি যে লোকেদের খুব বড় গ্রিড রয়েছে । আমরা এমন কিছু পাঠাতে চাই না যাতে এটি কীভাবে ব্যবহার করা যায় তার সীমাবদ্ধতা থাকে, যখন একটি বিকল্প পদ্ধতি থাকে।

প্রতিটি লেআউট পদ্ধতিতে যে জিনিসগুলি বোঝা যায় না সেগুলি সম্পর্কে আমরা কী করব?

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

গ্রিডে রাজমিস্ত্রি একত্রিত করা ফরম্যাটিং প্রসঙ্গ এবং সারিবদ্ধকরণ বৈশিষ্ট্যের মতো জিনিসগুলির উপলব্ধতার মধ্যে এই স্পষ্ট লিঙ্কটি ভেঙে দেয়, যা প্রতি বিন্যাস প্রসঙ্গে বক্স অ্যালাইনমেন্ট স্পেসিফিকেশনে সংজ্ঞায়িত করা হয়।

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

এছাড়াও এমন নিদর্শন রয়েছে যা রাজমিস্ত্রিতে অর্থবহ হবে, উদাহরণস্বরূপ grid-template-columns: repeat(auto-fill, max-content) , কারণ আপনার ক্রস সীমাবদ্ধতা নেই, তবে গ্রিডে অবৈধ থাকতে হবে। নিম্নলিখিত বৈশিষ্ট্যগুলির একটি তালিকা যা আমরা ভিন্নভাবে আচরণ করার আশা করি বা ভিন্ন বৈধ মান আছে৷

  • grid-template-areas : গাঁথনিতে আপনি শুধুমাত্র প্রাথমিক সারিটি নন-মেনরি দিক নির্দেশ করতে পারেন।
  • grid-template : শর্টহ্যান্ডকে সমস্ত পার্থক্যের জন্য অ্যাকাউন্ট করতে হবে।
  • আইনি মানগুলির পার্থক্যের কারণে grid-template-columns এবং grid-template-rows জন্য সাইজিং মানগুলি ট্র্যাক করুন৷
  • grid-auto-flow রাজমিস্ত্রির ক্ষেত্রে প্রযোজ্য নয় এবং masonry-auto-flow গ্রিডে প্রযোজ্য নয়। আপনি যে লেআউট পদ্ধতিতে আছেন তার কারণে সেগুলিকে একত্রিত করা জিনিসগুলির সমস্যা তৈরি করবে যা অবৈধ৷
  • গ্রিডের চারটি স্থান নির্ধারণের বৈশিষ্ট্য রয়েছে ( grid-column-start এবং আরও অনেক কিছু), রাজমিস্ত্রির রয়েছে মাত্র দুটি।
  • গ্রিড justify-* এবং align-* বৈশিষ্ট্যগুলির ছয়টি ব্যবহার করতে পারে, তবে রাজমিস্ত্রি শুধুমাত্র ফ্লেক্সবক্সের মতো একটি উপসেট ব্যবহার করে।

ডেভেলপারদের দ্বারা সৃষ্ট সমস্ত নতুন ত্রুটির ক্ষেত্রে কী ঘটবে তা নির্দিষ্ট করার প্রয়োজন হবে এমন একটি মান ব্যবহার করে যা গ্রিড-ওয়াথ-মেসনরি বা গ্রিড-বিহীন রাজমিস্ত্রিতে বৈধ নয়। উদাহরণস্বরূপ, grid-template-columns: masonry বা grid-template-rows: masonry ব্যবহার করা বৈধ কিন্তু উভয়ই একবারে নয়। আপনি একবারে উভয় ব্যবহার করলে কি হবে? এই বিবরণগুলি নির্দিষ্ট করতে হবে যাতে সমস্ত ব্রাউজার একই জিনিস করে।

এই সব এখন এবং ভবিষ্যতে একটি স্পেসিফিকেশন দৃষ্টিকোণ থেকে জটিল হয়ে ওঠে। আমাদের নিশ্চিত করতে হবে যে সবকিছুই রাজমিস্ত্রির বিবেচনায় নেয় এবং এটি রাজমিস্ত্রিতে কাজ করে বা না করে। এটি বিকাশকারীদের দৃষ্টিকোণ থেকেও বিভ্রান্তিকর। কেন আপনার মাথায় রাখা উচিত যে display: grid কাজ করে না?

একটি বিকল্প প্রস্তাব

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

ক্লাসিক রাজমিস্ত্রির বিন্যাস

বেশিরভাগ লোকেরা যখন রাজমিস্ত্রির কথা ভাবেন, তখন তারা একাধিক, সমান আকারের কলাম সহ একটি বিন্যাসের কথা ভাবেন। এটি নিম্নলিখিত CSS ব্যবহার করে সংজ্ঞায়িত করা হবে, যার সমতুল্য গ্রিড বান্ডিল সংস্করণের চেয়ে একটি লাইন কম কোড প্রয়োজন।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem;
}

সমান আকারের ট্র্যাক।

বিভিন্ন কলাম প্রস্থের জন্য গ্রিড টাইপ ট্র্যাক সাইজিং ব্যবহার করুন

মিশ্র অভ্যন্তরীণ এবং স্থির ট্র্যাক সাইজিংয়ের সাথে পূর্বে উল্লিখিত সমস্যাগুলি ছাড়া, আপনি গ্রিড থেকে আপনার পছন্দের সমস্ত ট্র্যাক সাইজিং ব্যবহার করতে পারেন। যেমন WebKit ব্লগ পোস্ট থেকে উদাহরণ , সংকীর্ণ এবং প্রশস্ত কলাম পুনরাবৃত্তির একটি প্যাটার্ন৷

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(8rem, 1fr) minmax(16rem, 2fr)) minmax(8rem, 1fr);
  gap: 1rem;
}

প্রশস্ত এবং সরু আকারের ট্র্যাকগুলির একটি প্যাটার্ন৷

গাঁথনি জন্য অতিরিক্ত ট্র্যাক আকার

অতিরিক্ত ট্র্যাক সাইজিং বিকল্প রয়েছে যেগুলি আমরা গ্রিডে অনুমোদন করি না কারণ গ্রিড একটি দ্বি-মাত্রিক বিন্যাস পদ্ধতি। এগুলি রাজমিস্ত্রিতে কার্যকর হবে তবে যদি তারা গ্রিডে কাজ না করে তবে এটি বিভ্রান্তিকর হবে।

অটো-ফিলিং max-content আকারের ট্র্যাক।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, max-content);
  gap: 1rem;
}

অটো-ফিলিং auto আকারের ট্র্যাক, যা একই আকারের ট্র্যাক তৈরি করবে, সবচেয়ে বড়টিকে মিটমাট করার জন্য স্বয়ংক্রিয় আকারের ট্র্যাক তৈরি করবে৷

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
  gap: 1rem;
}

স্বয়ংক্রিয় আকারের ট্র্যাক সহ রাজমিস্ত্রি।

বিষয়বস্তুকে কলাম স্প্যান করার অনুমতি দিন এবং রাজমিস্ত্রির লেআউটে আইটেম রাখুন

একটি পৃথক রাজমিস্ত্রির স্পেসিফিকেশনে কলাম বিস্তৃত বিষয়বস্তু না থাকার কোন কারণ নেই। এটি একটি masonry-track সম্পত্তি ব্যবহার করতে পারে, masonry-track-start এবং masonry-track-end একটি সংক্ষিপ্ত হস্ত যেহেতু একটি রাজমিস্ত্রির বিন্যাসে থাকাকালীন জিনিসগুলিকে বিস্তৃত করার জন্য আপনার কাছে শুধুমাত্র একটি মাত্রা থাকে।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
}

.span-2 {
  masonry-track: span 2; /* spans two columns */
}

.placed {
  masonry-track: 2 / 5; /* covers tracks 2, 3, and 4 */
}

স্থাপন করা এবং বিস্তৃত আইটেম সঙ্গে রাজমিস্ত্রি.

সাব-মেসনরি বা সাবগ্রিড রাজমিস্ত্রির ট্র্যাক গ্রহণ করে

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

উপসংহার

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

আপনার যদি কোনো প্রতিক্রিয়া থাকে, তাহলে ইস্যু 9041- এ আলোচনায় যোগ দিন।

ব্রামাস, ট্যাব অ্যাটকিন্স-বিটনার, উনা ক্র্যাভেটস, ইয়ান কিলপ্যাট্রিক এবং ক্রিস হ্যারেলসনকে ধন্যবাদ এই পোস্টের পর্যালোচনা এবং আলোচনার জন্য

,

ক্রোম টিম ওয়েবে রাজমিস্ত্রির ধরণের লেআউটগুলির বাস্তবায়ন দেখতে আগ্রহী৷ যাইহোক, আমরা মনে করি যে সাম্প্রতিক ওয়েবকিট পোস্টে প্রস্তাবিত CSS গ্রিড স্পেসিফিকেশনের অংশ হিসাবে এটি বাস্তবায়ন করা একটি ভুল হবে। আমরা আরও মনে করি যে WebKit পোস্টটি রাজমিস্ত্রির এমন একটি সংস্করণের বিরুদ্ধে যুক্তি দিয়েছে যা কেউ প্রস্তাব করছে না।

তাই, এই পোস্টের উদ্দেশ্য ব্যাখ্যা করা যে কেন আমরা ক্রোমে CSS গ্রিড লেআউট স্পেসিফিকেশনের অংশ হিসাবে রাজমিস্ত্রি বাস্তবায়নের বিষয়ে উদ্বেগ প্রকাশ করি এবং বিকল্প প্রস্তাবটি কী সক্ষম করে তা স্পষ্ট করে। সংক্ষেপে:

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

রাজমিস্ত্রি গ্রিডের অংশ হওয়া উচিত?

ক্রোম টিম বিশ্বাস করে যে রাজমিস্ত্রি একটি পৃথক বিন্যাস পদ্ধতি হওয়া উচিত, যা display: masonry (অথবা অন্য একটি কীওয়ার্ডের উপর একটি ভাল নাম নির্ধারণ করা উচিত)। পরে এই পোস্টে, আপনি কোডে দেখতে কেমন হতে পারে তার কিছু উদাহরণ দেখতে পারেন।

দুটি সম্পর্কিত কারণ রয়েছে কেন আমরা মনে করি যে রাজমিস্ত্রি গ্রিড বিন্যাসের বাইরে আরও ভালভাবে সংজ্ঞায়িত করা হয়েছে—লেআউট পারফরম্যান্স সমস্যার সম্ভাব্যতা, এবং সত্য যে রাজমিস্ত্রি এবং গ্রিড উভয়ের বৈশিষ্ট্য রয়েছে যা একটি লেআউট পদ্ধতিতে বোঝা যায় কিন্তু অন্যটিতে নয়।

কর্মক্ষমতা

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

অতএব, আপনার যদি grid-template-columns: 200px auto 200px — গ্রিডে করা একটি খুব সাধারণ জিনিস—আপনি সমস্যায় পড়তে শুরু করেন। আপনি একবার সাবগ্রিড যোগ করলে এই সমস্যাগুলি সূচকীয় হয়ে ওঠে

একটি যুক্তি রয়েছে যে বেশিরভাগ লোকেরা এটির সাথে জড়িত হবে না, তবে আমরা ইতিমধ্যে জানি যে লোকেদের খুব বড় গ্রিড রয়েছে । আমরা এমন কিছু পাঠাতে চাই না যাতে এটি কীভাবে ব্যবহার করা যায় তার সীমাবদ্ধতা থাকে, যখন একটি বিকল্প পদ্ধতি থাকে।

প্রতিটি লেআউট পদ্ধতিতে যে জিনিসগুলি বোঝা যায় না সেগুলি সম্পর্কে আমরা কী করব?

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

গ্রিডে রাজমিস্ত্রি একত্রিত করা ফরম্যাটিং প্রসঙ্গ এবং সারিবদ্ধকরণ বৈশিষ্ট্যের মতো জিনিসগুলির উপলব্ধতার মধ্যে এই স্পষ্ট লিঙ্কটি ভেঙে দেয়, যা প্রতি বিন্যাস প্রসঙ্গে বক্স অ্যালাইনমেন্ট স্পেসিফিকেশনে সংজ্ঞায়িত করা হয়।

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

এছাড়াও এমন নিদর্শন রয়েছে যা রাজমিস্ত্রিতে অর্থবহ হবে, উদাহরণস্বরূপ grid-template-columns: repeat(auto-fill, max-content) , কারণ আপনার ক্রস সীমাবদ্ধতা নেই, তবে গ্রিডে অবৈধ থাকতে হবে। নিম্নলিখিত বৈশিষ্ট্যগুলির একটি তালিকা যা আমরা ভিন্নভাবে আচরণ করার আশা করি বা ভিন্ন বৈধ মান আছে৷

  • grid-template-areas : গাঁথনিতে আপনি শুধুমাত্র প্রাথমিক সারিটি নন-মেনরি দিক নির্দেশ করতে পারেন।
  • grid-template : শর্টহ্যান্ডকে সমস্ত পার্থক্যের জন্য অ্যাকাউন্ট করতে হবে।
  • আইনি মানগুলির পার্থক্যের কারণে grid-template-columns এবং grid-template-rows জন্য সাইজিং মানগুলি ট্র্যাক করুন৷
  • grid-auto-flow রাজমিস্ত্রির ক্ষেত্রে প্রযোজ্য নয় এবং masonry-auto-flow গ্রিডে প্রযোজ্য নয়। আপনি যে লেআউট পদ্ধতিতে আছেন তার কারণে সেগুলিকে একত্রিত করা জিনিসগুলির সমস্যা তৈরি করবে যা অবৈধ৷
  • গ্রিডের চারটি স্থান নির্ধারণের বৈশিষ্ট্য রয়েছে ( grid-column-start এবং আরও অনেক কিছু), রাজমিস্ত্রির রয়েছে মাত্র দুটি।
  • গ্রিড justify-* এবং align-* বৈশিষ্ট্যগুলির ছয়টি ব্যবহার করতে পারে, তবে রাজমিস্ত্রি শুধুমাত্র ফ্লেক্সবক্সের মতো একটি উপসেট ব্যবহার করে।

ডেভেলপারদের দ্বারা সৃষ্ট সমস্ত নতুন ত্রুটির ক্ষেত্রে কী ঘটবে তা নির্দিষ্ট করার প্রয়োজন হবে এমন একটি মান ব্যবহার করে যা গ্রিড-ওয়াথ-মেসনরি বা গ্রিড-বিহীন রাজমিস্ত্রিতে বৈধ নয়। উদাহরণস্বরূপ, grid-template-columns: masonry বা grid-template-rows: masonry ব্যবহার করা বৈধ কিন্তু উভয়ই একবারে নয়। আপনি একবারে উভয় ব্যবহার করলে কি হবে? এই বিবরণগুলি নির্দিষ্ট করতে হবে যাতে সমস্ত ব্রাউজার একই জিনিস করে।

এই সব এখন এবং ভবিষ্যতে একটি স্পেসিফিকেশন দৃষ্টিকোণ থেকে জটিল হয়ে ওঠে। আমাদের নিশ্চিত করতে হবে যে সবকিছুই রাজমিস্ত্রির বিবেচনায় নেয় এবং এটি রাজমিস্ত্রিতে কাজ করে বা না করে। এটি বিকাশকারীদের দৃষ্টিকোণ থেকেও বিভ্রান্তিকর। কেন আপনার মাথায় রাখা উচিত যে display: grid কাজ করে না?

একটি বিকল্প প্রস্তাব

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

ক্লাসিক রাজমিস্ত্রির বিন্যাস

বেশিরভাগ লোকেরা যখন রাজমিস্ত্রির কথা ভাবেন, তখন তারা একাধিক, সমান আকারের কলাম সহ একটি বিন্যাসের কথা ভাবেন। এটি নিম্নলিখিত CSS ব্যবহার করে সংজ্ঞায়িত করা হবে, যার সমতুল্য গ্রিড বান্ডিল সংস্করণের চেয়ে একটি লাইন কম কোড প্রয়োজন।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem;
}

সমান আকারের ট্র্যাক।

বিভিন্ন কলাম প্রস্থের জন্য গ্রিড টাইপ ট্র্যাক সাইজিং ব্যবহার করুন

মিশ্র অভ্যন্তরীণ এবং স্থির ট্র্যাক সাইজিংয়ের সাথে পূর্বে উল্লিখিত সমস্যাগুলি ছাড়া, আপনি গ্রিড থেকে আপনার পছন্দের সমস্ত ট্র্যাক সাইজিং ব্যবহার করতে পারেন। যেমন WebKit ব্লগ পোস্ট থেকে উদাহরণ , সংকীর্ণ এবং প্রশস্ত কলাম পুনরাবৃত্তির একটি প্যাটার্ন৷

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(8rem, 1fr) minmax(16rem, 2fr)) minmax(8rem, 1fr);
  gap: 1rem;
}

প্রশস্ত এবং সরু আকারের ট্র্যাকগুলির একটি প্যাটার্ন৷

গাঁথনি জন্য অতিরিক্ত ট্র্যাক আকার

অতিরিক্ত ট্র্যাক সাইজিং বিকল্প রয়েছে যেগুলি আমরা গ্রিডে অনুমোদন করি না কারণ গ্রিড একটি দ্বি-মাত্রিক বিন্যাস পদ্ধতি। এগুলি রাজমিস্ত্রিতে কার্যকর হবে তবে যদি তারা গ্রিডে কাজ না করে তবে এটি বিভ্রান্তিকর হবে।

অটো-ফিলিং max-content আকারের ট্র্যাক।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, max-content);
  gap: 1rem;
}

অটো-ফিলিং auto আকারের ট্র্যাক, যা একই আকারের ট্র্যাক তৈরি করবে, সবচেয়ে বড়টিকে মিটমাট করার জন্য স্বয়ংক্রিয় আকারের ট্র্যাক তৈরি করবে৷

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
  gap: 1rem;
}

স্বয়ংক্রিয় আকারের ট্র্যাক সহ রাজমিস্ত্রি।

বিষয়বস্তুকে কলাম স্প্যান করার অনুমতি দিন এবং রাজমিস্ত্রির লেআউটে আইটেম রাখুন

একটি পৃথক রাজমিস্ত্রির স্পেসিফিকেশনে কলাম বিস্তৃত বিষয়বস্তু না থাকার কোন কারণ নেই। এটি একটি masonry-track সম্পত্তি ব্যবহার করতে পারে, masonry-track-start এবং masonry-track-end একটি সংক্ষিপ্ত হস্ত যেহেতু একটি রাজমিস্ত্রির বিন্যাসে থাকাকালীন জিনিসগুলিকে বিস্তৃত করার জন্য আপনার কাছে শুধুমাত্র একটি মাত্রা থাকে।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
}

.span-2 {
  masonry-track: span 2; /* spans two columns */
}

.placed {
  masonry-track: 2 / 5; /* covers tracks 2, 3, and 4 */
}

স্থাপন করা এবং বিস্তৃত আইটেম সঙ্গে রাজমিস্ত্রি.

সাব-মেসনরি বা সাবগ্রিড রাজমিস্ত্রির ট্র্যাক গ্রহণ করে

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

উপসংহার

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

আপনার যদি কোনো প্রতিক্রিয়া থাকে, তাহলে ইস্যু 9041- এ আলোচনায় যোগ দিন।

ব্রামাস, ট্যাব অ্যাটকিন্স-বিটনার, উনা ক্র্যাভেটস, ইয়ান কিলপ্যাট্রিক এবং ক্রিস হ্যারেলসনকে ধন্যবাদ এই পোস্টের পর্যালোচনা এবং আলোচনার জন্য

,

ক্রোম টিম ওয়েবে রাজমিস্ত্রির ধরণের লেআউটগুলির বাস্তবায়ন দেখতে আগ্রহী৷ যাইহোক, আমরা মনে করি যে সাম্প্রতিক ওয়েবকিট পোস্টে প্রস্তাবিত CSS গ্রিড স্পেসিফিকেশনের অংশ হিসাবে এটি বাস্তবায়ন করা একটি ভুল হবে। আমরা আরও মনে করি যে WebKit পোস্টটি রাজমিস্ত্রির এমন একটি সংস্করণের বিরুদ্ধে যুক্তি দিয়েছে যা কেউ প্রস্তাব করছে না।

তাই, এই পোস্টের উদ্দেশ্য ব্যাখ্যা করা যে কেন আমরা ক্রোমে CSS গ্রিড লেআউট স্পেসিফিকেশনের অংশ হিসাবে রাজমিস্ত্রি বাস্তবায়নের বিষয়ে উদ্বেগ প্রকাশ করি এবং বিকল্প প্রস্তাবটি কী সক্ষম করে তা স্পষ্ট করে। সংক্ষেপে:

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

রাজমিস্ত্রি গ্রিডের অংশ হওয়া উচিত?

ক্রোম টিম বিশ্বাস করে যে রাজমিস্ত্রি একটি পৃথক বিন্যাস পদ্ধতি হওয়া উচিত, যা display: masonry (অথবা অন্য একটি কীওয়ার্ডের উপর একটি ভাল নাম নির্ধারণ করা উচিত)। পরে এই পোস্টে, আপনি কোডে দেখতে কেমন হতে পারে তার কিছু উদাহরণ দেখতে পারেন।

দুটি সম্পর্কিত কারণ রয়েছে কেন আমরা মনে করি যে রাজমিস্ত্রি গ্রিড বিন্যাসের বাইরে আরও ভালভাবে সংজ্ঞায়িত করা হয়েছে—লেআউট পারফরম্যান্স সমস্যার সম্ভাব্যতা, এবং সত্য যে রাজমিস্ত্রি এবং গ্রিড উভয়ের বৈশিষ্ট্য রয়েছে যা একটি লেআউট পদ্ধতিতে বোঝা যায় কিন্তু অন্যটিতে নয়।

কর্মক্ষমতা

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

অতএব, আপনার যদি grid-template-columns: 200px auto 200px — গ্রিডে করা একটি খুব সাধারণ জিনিস—আপনি সমস্যায় পড়তে শুরু করেন। আপনি একবার সাবগ্রিড যোগ করলে এই সমস্যাগুলি সূচকীয় হয়ে ওঠে

একটি যুক্তি আছে যে বেশিরভাগ লোকেরা এটির সাথে জড়িত হবে না, তবে আমরা ইতিমধ্যে জানি যে লোকেদের খুব বড় গ্রিড রয়েছে । আমরা এমন কিছু পাঠাতে চাই না যাতে এটি কীভাবে ব্যবহার করা যায় তার সীমাবদ্ধতা থাকে, যখন একটি বিকল্প পদ্ধতি থাকে।

প্রতিটি লেআউট পদ্ধতিতে যে জিনিসগুলি বোঝা যায় না সেগুলি সম্পর্কে আমরা কী করব?

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

গ্রিডে রাজমিস্ত্রি একত্রিত করা ফরম্যাটিং প্রসঙ্গ এবং সারিবদ্ধকরণ বৈশিষ্ট্যের মতো জিনিসগুলির উপলব্ধতার মধ্যে এই স্পষ্ট লিঙ্কটি ভেঙে দেয়, যা প্রতি বিন্যাস প্রসঙ্গে বক্স অ্যালাইনমেন্ট স্পেসিফিকেশনে সংজ্ঞায়িত করা হয়।

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

এছাড়াও এমন নিদর্শন রয়েছে যা রাজমিস্ত্রিতে অর্থবহ হবে, উদাহরণস্বরূপ grid-template-columns: repeat(auto-fill, max-content) , কারণ আপনার ক্রস সীমাবদ্ধতা নেই, তবে গ্রিডে অবৈধ থাকতে হবে। নিম্নলিখিত বৈশিষ্ট্যগুলির একটি তালিকা যা আমরা ভিন্নভাবে আচরণ করার আশা করি বা ভিন্ন বৈধ মান আছে৷

  • grid-template-areas : গাঁথনিতে আপনি শুধুমাত্র প্রাথমিক সারিটি নন-মেনরি দিক নির্দেশ করতে পারেন।
  • grid-template : শর্টহ্যান্ডকে সমস্ত পার্থক্যের জন্য অ্যাকাউন্ট করতে হবে।
  • আইনি মানগুলির পার্থক্যের কারণে grid-template-columns এবং grid-template-rows জন্য সাইজিং মানগুলি ট্র্যাক করুন৷
  • grid-auto-flow রাজমিস্ত্রির ক্ষেত্রে প্রযোজ্য নয় এবং masonry-auto-flow গ্রিডে প্রযোজ্য নয়। আপনি যে লেআউট পদ্ধতিতে আছেন তার কারণে সেগুলিকে একত্রিত করা জিনিসগুলির সমস্যা তৈরি করবে যা অবৈধ৷
  • গ্রিডের চারটি স্থান নির্ধারণের বৈশিষ্ট্য রয়েছে ( grid-column-start এবং আরও অনেক কিছু), রাজমিস্ত্রির রয়েছে মাত্র দুটি।
  • গ্রিড justify-* এবং align-* বৈশিষ্ট্যগুলির ছয়টি ব্যবহার করতে পারে, তবে রাজমিস্ত্রি শুধুমাত্র ফ্লেক্সবক্সের মতো একটি উপসেট ব্যবহার করে।

ডেভেলপারদের দ্বারা সৃষ্ট সমস্ত নতুন ত্রুটির ক্ষেত্রে কী ঘটবে তা নির্দিষ্ট করার প্রয়োজন হবে এমন একটি মান ব্যবহার করে যা গ্রিড-ওয়াথ-মেসনরি বা গ্রিড-বিহীন রাজমিস্ত্রিতে বৈধ নয়। উদাহরণস্বরূপ, grid-template-columns: masonry বা grid-template-rows: masonry ব্যবহার করা বৈধ কিন্তু উভয়ই একবারে নয়। আপনি একবারে উভয় ব্যবহার করলে কি হবে? এই বিবরণগুলি নির্দিষ্ট করতে হবে যাতে সমস্ত ব্রাউজার একই জিনিস করে।

এই সব এখন এবং ভবিষ্যতে একটি স্পেসিফিকেশন দৃষ্টিকোণ থেকে জটিল হয়ে ওঠে। আমাদের নিশ্চিত করতে হবে যে সবকিছুই রাজমিস্ত্রির বিবেচনায় নেয় এবং এটি রাজমিস্ত্রিতে কাজ করে বা না করে। এটি বিকাশকারীদের দৃষ্টিকোণ থেকেও বিভ্রান্তিকর। কেন আপনার মাথায় রাখা উচিত যে display: grid কাজ করে না?

একটি বিকল্প প্রস্তাব

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

ক্লাসিক রাজমিস্ত্রির বিন্যাস

বেশিরভাগ লোকেরা যখন রাজমিস্ত্রির কথা ভাবেন, তখন তারা একাধিক, সমান আকারের কলাম সহ একটি বিন্যাসের কথা ভাবেন। এটি নিম্নলিখিত CSS ব্যবহার করে সংজ্ঞায়িত করা হবে, যার সমতুল্য গ্রিড বান্ডিল সংস্করণের চেয়ে একটি লাইন কম কোড প্রয়োজন।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem;
}

সমান আকারের ট্র্যাক।

বিভিন্ন কলাম প্রস্থের জন্য গ্রিড টাইপ ট্র্যাক সাইজিং ব্যবহার করুন

মিশ্র অভ্যন্তরীণ এবং স্থির ট্র্যাক সাইজিংয়ের সাথে পূর্বে উল্লিখিত সমস্যাগুলি ছাড়া, আপনি গ্রিড থেকে আপনার পছন্দের সমস্ত ট্র্যাক সাইজিং ব্যবহার করতে পারেন। যেমন WebKit ব্লগ পোস্ট থেকে উদাহরণ , সংকীর্ণ এবং প্রশস্ত কলাম পুনরাবৃত্তির একটি প্যাটার্ন৷

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(8rem, 1fr) minmax(16rem, 2fr)) minmax(8rem, 1fr);
  gap: 1rem;
}

প্রশস্ত এবং সরু আকারের ট্র্যাকগুলির একটি প্যাটার্ন৷

গাঁথনি জন্য অতিরিক্ত ট্র্যাক আকার

অতিরিক্ত ট্র্যাক সাইজিং বিকল্প রয়েছে যেগুলি আমরা গ্রিডে অনুমোদন করি না কারণ গ্রিড একটি দ্বি-মাত্রিক বিন্যাস পদ্ধতি। এগুলি রাজমিস্ত্রিতে কার্যকর হবে তবে যদি তারা গ্রিডে কাজ না করে তবে এটি বিভ্রান্তিকর হবে।

অটো-ফিলিং max-content আকারের ট্র্যাক।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, max-content);
  gap: 1rem;
}

অটো-ফিলিং auto আকারের ট্র্যাক, যা একই আকারের ট্র্যাক তৈরি করবে, সবচেয়ে বড়টিকে মিটমাট করার জন্য স্বয়ংক্রিয় আকারের ট্র্যাক তৈরি করবে৷

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
  gap: 1rem;
}

স্বয়ংক্রিয় আকারের ট্র্যাক সহ রাজমিস্ত্রি।

বিষয়বস্তুকে কলাম স্প্যান করার অনুমতি দিন এবং রাজমিস্ত্রির লেআউটে আইটেম রাখুন

একটি পৃথক রাজমিস্ত্রির স্পেসিফিকেশনে কলাম বিস্তৃত বিষয়বস্তু না থাকার কোন কারণ নেই। এটি একটি masonry-track সম্পত্তি ব্যবহার করতে পারে, masonry-track-start এবং masonry-track-end একটি সংক্ষিপ্ত হস্ত যেহেতু একটি রাজমিস্ত্রির বিন্যাসে থাকাকালীন জিনিসগুলিকে বিস্তৃত করার জন্য আপনার কাছে শুধুমাত্র একটি মাত্রা থাকে।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
}

.span-2 {
  masonry-track: span 2; /* spans two columns */
}

.placed {
  masonry-track: 2 / 5; /* covers tracks 2, 3, and 4 */
}

স্থাপন করা এবং বিস্তৃত আইটেম সঙ্গে রাজমিস্ত্রি.

সাব-মেসনরি বা সাবগ্রিড রাজমিস্ত্রির ট্র্যাক গ্রহণ করে

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

উপসংহার

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

আপনার যদি কোনো প্রতিক্রিয়া থাকে, তাহলে ইস্যু 9041- এ আলোচনায় যোগ দিন।

ব্রামাস, ট্যাব অ্যাটকিন্স-বিটনার, উনা ক্র্যাভেটস, ইয়ান কিলপ্যাট্রিক এবং ক্রিস হ্যারেলসনকে ধন্যবাদ এই পোস্টের পর্যালোচনা এবং আলোচনার জন্য

,

ক্রোম টিম ওয়েবে রাজমিস্ত্রির ধরণের লেআউটগুলির বাস্তবায়ন দেখতে আগ্রহী৷ যাইহোক, আমরা মনে করি যে সাম্প্রতিক ওয়েবকিট পোস্টে প্রস্তাবিত CSS গ্রিড স্পেসিফিকেশনের অংশ হিসাবে এটি বাস্তবায়ন করা একটি ভুল হবে। আমরা আরও মনে করি যে WebKit পোস্টটি রাজমিস্ত্রির এমন একটি সংস্করণের বিরুদ্ধে যুক্তি দিয়েছে যা কেউ প্রস্তাব করছে না।

তাই, এই পোস্টের উদ্দেশ্য ব্যাখ্যা করা যে কেন আমরা ক্রোমে CSS গ্রিড লেআউট স্পেসিফিকেশনের অংশ হিসাবে রাজমিস্ত্রি বাস্তবায়নের বিষয়ে উদ্বেগ প্রকাশ করি এবং বিকল্প প্রস্তাবটি কী সক্ষম করে তা স্পষ্ট করে। সংক্ষেপে:

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

রাজমিস্ত্রি গ্রিডের অংশ হওয়া উচিত?

ক্রোম টিম বিশ্বাস করে যে রাজমিস্ত্রি একটি পৃথক বিন্যাস পদ্ধতি হওয়া উচিত, যা display: masonry (অথবা অন্য একটি কীওয়ার্ডের উপর একটি ভাল নাম নির্ধারণ করা উচিত)। পরে এই পোস্টে, আপনি কোডে দেখতে কেমন হতে পারে তার কিছু উদাহরণ দেখতে পারেন।

দুটি সম্পর্কিত কারণ রয়েছে কেন আমরা মনে করি যে রাজমিস্ত্রি গ্রিড বিন্যাসের বাইরে আরও ভালভাবে সংজ্ঞায়িত করা হয়েছে—লেআউট পারফরম্যান্স সমস্যার সম্ভাব্যতা, এবং সত্য যে রাজমিস্ত্রি এবং গ্রিড উভয়ের বৈশিষ্ট্য রয়েছে যা একটি লেআউট পদ্ধতিতে বোঝা যায় কিন্তু অন্যটিতে নয়।

কর্মক্ষমতা

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

অতএব, আপনার যদি grid-template-columns: 200px auto 200px — গ্রিডে করা একটি খুব সাধারণ জিনিস—আপনি সমস্যায় পড়তে শুরু করেন। আপনি একবার সাবগ্রিড যোগ করলে এই সমস্যাগুলি সূচকীয় হয়ে ওঠে

একটি যুক্তি রয়েছে যে বেশিরভাগ লোকেরা এটির সাথে জড়িত হবে না, তবে আমরা ইতিমধ্যে জানি যে লোকেদের খুব বড় গ্রিড রয়েছে । আমরা এমন কিছু পাঠাতে চাই না যাতে এটি কীভাবে ব্যবহার করা যায় তার সীমাবদ্ধতা থাকে, যখন একটি বিকল্প পদ্ধতি থাকে।

প্রতিটি লেআউট পদ্ধতিতে যে জিনিসগুলি বোঝা যায় না সেগুলি সম্পর্কে আমরা কী করব?

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

গ্রিডে রাজমিস্ত্রি একত্রিত করা ফরম্যাটিং প্রসঙ্গ এবং সারিবদ্ধকরণ বৈশিষ্ট্যের মতো জিনিসগুলির উপলব্ধতার মধ্যে এই স্পষ্ট লিঙ্কটি ভেঙে দেয়, যা প্রতি বিন্যাস প্রসঙ্গে বক্স অ্যালাইনমেন্ট স্পেসিফিকেশনে সংজ্ঞায়িত করা হয়।

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

এছাড়াও এমন নিদর্শন রয়েছে যা রাজমিস্ত্রিতে অর্থবহ হবে, উদাহরণস্বরূপ grid-template-columns: repeat(auto-fill, max-content) , কারণ আপনার ক্রস সীমাবদ্ধতা নেই, তবে গ্রিডে অবৈধ থাকতে হবে। নিম্নলিখিত বৈশিষ্ট্যগুলির একটি তালিকা যা আমরা ভিন্নভাবে আচরণ করার আশা করি বা ভিন্ন বৈধ মান আছে৷

  • grid-template-areas : গাঁথনিতে আপনি শুধুমাত্র প্রাথমিক সারিটি নন-মেনরি দিক নির্দেশ করতে পারেন।
  • grid-template : শর্টহ্যান্ডকে সমস্ত পার্থক্যের জন্য অ্যাকাউন্ট করতে হবে।
  • আইনি মানগুলির পার্থক্যের কারণে grid-template-columns এবং grid-template-rows জন্য সাইজিং মানগুলি ট্র্যাক করুন৷
  • grid-auto-flow রাজমিস্ত্রির ক্ষেত্রে প্রযোজ্য নয় এবং masonry-auto-flow গ্রিডে প্রযোজ্য নয়। আপনি যে লেআউট পদ্ধতিতে আছেন তার কারণে সেগুলিকে একত্রিত করা জিনিসগুলির সমস্যা তৈরি করবে যা অবৈধ৷
  • গ্রিডের চারটি স্থান নির্ধারণের বৈশিষ্ট্য রয়েছে ( grid-column-start এবং আরও অনেক কিছু), রাজমিস্ত্রির রয়েছে মাত্র দুটি।
  • গ্রিড justify-* এবং align-* বৈশিষ্ট্যগুলির ছয়টি ব্যবহার করতে পারে, তবে রাজমিস্ত্রি শুধুমাত্র ফ্লেক্সবক্সের মতো একটি উপসেট ব্যবহার করে।

ডেভেলপারদের দ্বারা সৃষ্ট সমস্ত নতুন ত্রুটির ক্ষেত্রে কী ঘটবে তা নির্দিষ্ট করার প্রয়োজন হবে এমন একটি মান ব্যবহার করে যা গ্রিড-ওয়াথ-মেসনরি বা গ্রিড-বিহীন রাজমিস্ত্রিতে বৈধ নয়। উদাহরণস্বরূপ, grid-template-columns: masonry বা grid-template-rows: masonry ব্যবহার করা বৈধ কিন্তু উভয়ই একবারে নয়। আপনি একবারে উভয় ব্যবহার করলে কি হবে? এই বিবরণগুলি নির্দিষ্ট করতে হবে যাতে সমস্ত ব্রাউজার একই জিনিস করে।

এই সব এখন এবং ভবিষ্যতে একটি স্পেসিফিকেশন দৃষ্টিকোণ থেকে জটিল হয়ে ওঠে। আমাদের নিশ্চিত করতে হবে যে সমস্ত কিছু অ্যাকাউন্টে রাজমিস্ত্রি নেয় এবং এটি রাজমিস্ত্রিতে কাজ করে না বা না। এটি বিকাশকারীদের দৃষ্টিকোণ থেকেও বিভ্রান্তিকর। আপনার কেন আপনার মাথায় রাখা দরকার যে display: grid কিছু জিনিস রাজমিস্ত্রি ব্যবহারের কারণে কাজ করে না?

একটি বিকল্প প্রস্তাব

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

ক্লাসিক রাজমিস্ত্রি বিন্যাস

যখন বেশিরভাগ লোকেরা রাজমিস্ত্রির কথা ভাবেন, তারা একাধিক, সমান আকারের কলাম সহ একটি লেআউটের কথা ভাবেন। এটি নিম্নলিখিত সিএসএস ব্যবহার করে সংজ্ঞায়িত করা হবে, যার সমতুল্য গ্রিড বান্ডিল সংস্করণের চেয়ে লাইন কম কোড প্রয়োজন।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem;
}

সমান আকারের ট্র্যাক।

বিভিন্ন কলাম প্রস্থের জন্য গ্রিড টাইপ ট্র্যাক সাইজিং ব্যবহার করুন

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

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(8rem, 1fr) minmax(16rem, 2fr)) minmax(8rem, 1fr);
  gap: 1rem;
}

প্রশস্ত এবং সরু আকারের ট্র্যাকগুলির একটি প্যাটার্ন।

রাজমিস্ত্রি জন্য অতিরিক্ত ট্র্যাক সাইজিং

গ্রিডটি দ্বি-মাত্রিক বিন্যাস পদ্ধতি হ'ল এই কারণে আমরা গ্রিডে অনুমতি দিই না এমন অতিরিক্ত ট্র্যাক সাইজিং বিকল্প রয়েছে। এগুলি রাজমিস্ত্রিতে কার্যকর হবে তবে তারা গ্রিডে কাজ না করলে এটি বিভ্রান্তিকর হবে।

অটো-ফিলিং max-content আকারের ট্র্যাকগুলি।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, max-content);
  gap: 1rem;
}

অটো-ফিলিং auto আকারের ট্র্যাকগুলি, যা একই আকারের ট্র্যাকগুলি তৈরি করবে, সবচেয়ে বড়টিকে সামঞ্জস্য করার জন্য অটো আকারের।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
  gap: 1rem;
}

অটো আকারের ট্র্যাক সহ রাজমিস্ত্রি।

বিষয়বস্তুগুলিকে স্প্যান করার জন্য সামগ্রীকে অনুমতি দিন এবং রাজমিস্ত্রি বিন্যাসে আইটেমগুলি রাখুন

পৃথক রাজমিস্ত্রি স্পেসিফিকেশনে সামগ্রী বিস্তৃত কলাম না রাখার কোনও কারণ নেই। এটি একটি masonry-track সম্পত্তি ব্যবহার করতে পারে, masonry-track-start এবং masonry-track-end জন্য একটি শর্টহ্যান্ড হওয়ায় আপনার কেবল রাজমিস্ত্রি লেআউটে থাকাকালীন জিনিসগুলি বিস্তৃত করার একটি মাত্রা রয়েছে।

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
}

.span-2 {
  masonry-track: span 2; /* spans two columns */
}

.placed {
  masonry-track: 2 / 5; /* covers tracks 2, 3, and 4 */
}

স্থাপন এবং বিস্তৃত আইটেম সহ রাজমিস্ত্রি।

উপ-ম্যাসোনারি বা সাবগ্রিড গ্রহণকারী রাজমিস্ত্রি ট্র্যাকগুলি

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

উপসংহার

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

আপনার যদি কোনও প্রতিক্রিয়া থাকে তবে 9041 ইস্যুতে আলোচনায় যোগ দিন।

এই পোস্টটি পর্যালোচনা করার জন্য ব্রামাস, ট্যাব অ্যাটকিনস-বিটনার, উনা ক্রাভেটস, ইয়ান কিলপ্যাট্রিক এবং ক্রিস হ্যারেলসনকে ধন্যবাদ জানাই।