Unlimited Wordpress themes, plugins, graphics & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Web Design
  2. CSS Grid Layout

CSS গ্রিড লেআউট: গ্রিড এরিয়ার ব্যবহার

by
Difficulty:BeginnerLength:ShortLanguages:
This post is part of a series called Understanding the CSS Grid Layout Module.
CSS Grid Layout: Fluid Columns and Better Gutters
CSS Grid Layout: Going Responsive With auto-fill and minmax()

Bengali (বাংলা) translation by Shakila Humaira (you can also view the original English article)

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

গ্রিড এরিয়াসমূহ সংজ্ঞায়িত করা

এখানে আমরা নিচের গ্রিডটি নিয়ে কাজ করছি: এই গ্রিডে মোট নয়টি গ্রিড আইটেম আছে যা তিনটি সমান্তরাল কলাম ও সারিতে 20px গাটারসহ বিভক্ত হয়ে গেছে। 

বর্তমানে আমাদের আইটেমগুলোতে কেবল রঙ এর জন্য কিছু স্টাইল আছে, কিন্তু আমরা প্রথম টিউটোরিয়ালে ফিরে যাবো এবং সেখান থেকে কিছু grid-column এবং grid-row রুলসের প্রয়োগ করবো, এখানে এমন কিছু রুলস দেয়া হলো:

এই শর্টহ্যান্ড grid-column স্টেটমেন্টে আমরা বেশ কার্যকরভাবে grid-column-start এবং grid-column-end ব্যবহার করেছি, যার ফলে আইটেমগুলো গ্রিড লাইন ১ এ শুরু হবে এবং গ্রিড লাইন ৩ এ শেষ হবে। 

grid lines
গ্রিড লাইন ১ এবং ৩

এখানে আমরা এবার যা পেলাম; প্রথম আইটেম দুইটি সেলে ছড়িয়ে গেছে, যার ফলে অটো প্লেসমেন্ট অ্যালগরিদমের কারনে অন্যান্য আইটেমগুলো ডানদিকে এবং নিচের দিকে সরে গেছে। 

সারির ক্ষেত্রেও একই প্রক্রিয়াটি করা যেতে পারে, যার ফলে আমরা গ্রিডের উপরের বামদিকে বেশ বড় একটি এরিয়া পাবো।

সেলসমূহ স্প্যান করা

আরও সহজ সিনট্যাক্স ব্যবহার করে আমরা grid-column-end কে span কীওয়ার্ডে রুপান্তর করতে পারি। span দিয়ে আমাদেরকে নির্দিষ্ট করে বলতে হবে না যে এই এরিয়াটি কোথায় শেষ হবে, এর পরিবর্তে এই আইটেমটি কয়টি ট্র্যাক অতিক্রম করবে তা সংজ্ঞায়িত করতে হবে:

পরিশেষে আমরা একই রকম ফলাফল পাবো, কিন্তু এক্ষেত্রে আমরা যদি এর শুরুটা কোথা থেকে হবে তা পরিবর্তন করে দেই, তাহলে শেষটাও বাধ্যতামূলকভাবে পরিবর্তন করতে হবে না।

নিচের  ডেমোতে আপনি দেখতে পাচ্ছেন আমরা চারটি আইটেম মুছে ফেলার মাধ্যমে এই লেআউটটি কিছুটা খালি করেছি।  আমরা আমাদের দুটি আইটেমের পজিশন ঠিক করেছি: প্রথমটি দুটি কলাম ও দুটি সারি জুড়ে আছে এবং চার নং আইটেমটি কলাম ৩ এ ২ নং সারিতে শুরু হয়েছে এবং নিচের দিকটি জুড়ে রয়েছে:

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

নোট: এমন অনেক পরিস্থিতি আছে যেখানে সোর্স অর্ডারকে অবশ্যই কোনও উপস্থাপনায় তুলে ধরতে হয়-তবে আক্সেসিবিলিটি/প্রবেশযোগ্যতার কথা কখনই ভুলবেন না।

নামযুক্ত এরিয়াসমূহ

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

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

  • হেডার
  • মেইন কন্টেন্ট
  • সাইডবার
  • ফুটার

আমরা আমাদের গ্রিড কন্টেইনারের ভিতরেই এই এরিয়াগুলো সংজ্ঞায়িত করেছি, এবং আমরা এখন এগুলো বাস্তবায়ন করতে যাচ্ছি:

আইটেমগুলোর অবস্থান ঠিক করা

এখন আমরা আইটেমের প্রতি আমাদের মনোযোগ দিবো, এবং grid-column এবং grid-row রুল দুটি grid-area এর অনুকূলে সাজাবো:

আমাদের প্রথম আইটেমটি হেডারে পরিণত হবে, যা সম্পূর্ণ তিনটি কলামের জায়গা জুড়ে থাকবে। আমাদের দ্বিতীয় আইটেমটি মূল কনটেন্ট এরিয়া হিসেবে থাকবে, তৃতীয়টি হবে সাইডবার এবং চতুর্থটি ফুটার। এগুলোর একটিও সোর্স অর্ডার অনুসরণ করবে না ফলে item-4 সহজেই হেডার এরিয়ার পরে অবস্থান নিতে পারবে। 

আপনি দেখতেই পাচ্ছেন এর ফলে একটি পেইজের বিন্যাস তৈরি করা খুব সহজ হয়ে গেছে। যাই হোক, যদিও আমরা এখন আমাদের গ্রিড দৃশ্যমান করার মেজাজে আছি, তাহলে আরো অগ্রসর হয়ে ইমোজিসমূহ ব্যবহার করতে দোষ কি?!

গ্রিড এরিয়া নির্মাণ করা

আমাদের ওয়েব পেইজে সব ধরণের নেস্টেড কম্পোনেন্টসমূহ থাকবে, তাই এবার দেখা যাক এটা গ্রিড এরিয়ার সঙ্গে কিভাবে কাজ করে।

যখন আমরা কোনও গ্রিড কন্টেইনারকে display: grid; দিয়ে ঘোষণা করি, তখন কেবল এর  অধঃস্তন এলিমেন্টগুলোই গ্রিড আইটেম হয়।  কিন্তু এই চাইল্ড এলিমেন্টগুলোর নিচে যেসব কন্টেন্ট যুক্ত করা হবে সেগুলো গ্রিডের প্রভাবমুক্ত থাকবে যে পর্যন্ত না আমরা সেগুলো নির্দিষ্টভাবে বলে না দেই। 

আমাদের উদাহরনে, আমরা এই মার্কআপের শেষে .item-5 , .item-6, এবং .item-7 পুনরায় যোগ করতে যাচ্ছি, যা .item-2 এর অধীনে থাকবে।

তাই এখন পুনরায় আমাদের .item-2 কে গ্রিড কন্টেইনার হিসেবে ঘোষণা করতে হবে, যাতে এই গ্রিডে দুটি কলাম এবং দুটি সারি থাকে। 

এখানেও আমরা header”, “article”, এবং “sidebar” পুনরায় ব্যবহার করতে পারি; এতে কোনও সন্দেহ নেই, কারন সব কিছুই আগের প্রসঙ্গানুসারে থাকবে।  এই গ্রিড এরিয়া কেবল .item-2 এর ভিতর গ্রিড ব্যবহার করবে।

পরিশিষ্ট

আমরা এ পর্যন্ত যা কিছু বলেছি তার সারসংক্ষেপ:

  1. grid-column দিয়ে আমরা শর্টহ্যাণ্ড পদ্ধতিতে গ্রিডের একটি আইটেম কোথায় শুরু হবে ও শেষ হবে তা সংজ্ঞায়িত করতে পারি। 
  2. আমরা span কীওয়ার্ড ব্যবহার করে আমাদের রুলসগুলোকে আরও নমনীয় ও পরিবর্তনশীল করে তুলতে পারি। 
  3. grid-template-areas দিয়ে আমরা গ্রিড এরিয়াগুলোকে নামকরণ করতে পারি (এমনকি ইমোজি ব্যবহার করেও, যদি এই ধরণের মেজাজ থাকে)। 
  4. এছাড়াও আমরা প্রয়োজনে গ্রিড আইটেমগুলোকে display: grid; ব্যবহার করে নেস্টেড করতে পারি, এবং একই প্রক্রিয়া অনুসরণ করতে পারি।

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

দরকারী রিসোর্সসমূহ

  • আমি কি এটা এরই মধ্যে উল্লেখ করেছি?  @rachelandrew কে ফলো করুন।
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.