Students Save 30%! Learn & create with unlimited courses & creative assets Students Save 30%! Save Now
Advertisement
  1. Web Design
  2. CSS Grid Layout
Webdesign

CSS গ্রীড দিয়ে যেভাবে তৈরি করবেন একটি অফ ক্যানভাস ন্যাভিগেশন

by
Difficulty:IntermediateLength:ShortLanguages:

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

অফ-ক্যানভাস প্যাটার্ন রেস্পন্সিভ নেভিগেশনের জন্য একটি ক্লাসিক পন্থা। যখন কোনও ওয়েবসাইটের "viewport" যথেষ্ট পরিমানে ছোট হয়, তখন বড় ন্যাভিগেশন ম্যানুটি লুকানো থাকে এবং কেবল ক্লিক করলেই তা দেখানো হয়ে থাকে।   

আমরা আজকে অফ-ক্যানভাস ন্যাভিগেশন তৈরি করতে যাচ্ছি, এবং শুধুমাত্র CSS ব্যবহার করে আমরা এটা করবো (কোনও JavaScript এর দরকার নেই) এক্ষেত্রে গ্রীড ব্যবহার করে আমরা আমাদের পেইজ স্ট্রাকচার ঠিক করে নিবো। এখানে আছে সম্পূর্ণ পেইজ ডেমো যার উপর আমরা কাজ করছি।  

মৌলিক পেইজের গঠন

চলুন তাহলে মৌলিক পেইজ তৈরি করার মাধ্যমে শুরু করা যাক; আমরা নিচের মত কিছু একটা তৈরি করতে যাচ্ছিঃ

Semantic page structure
আক্ষরিকভাবে পৃষ্ঠার গঠন

এটা হচ্ছে মোটামুটিভাবে একটি রুপক আক্ষরিক পেইজের কাঠামো; আপনি দেখতে পাবেন যে সবকিছু ছোট viewport এর জন্য একক কলামে আছে, এরপর তার পাশেরটা বড় স্ক্রিণে দেখাচ্ছে। <nav> এলিমেন্টটি আরও স্বচ্ছভাবে বুঝানোর জন্য তাতে নীল রং দিয়ে হাইলাইট করা হয়েছে। 

আমাদের প্রাথমিক মার্কআপটি এখানে দেখানো হলোঃ

এখন তাহলে চলুন কিছু ভিজুয়াল স্টাইল এবং কিছু গ্রীড রুলস যোগ করা যাক। 

নতুন গ্রীড যোগ করুন

চলুন, তাহলে আমাদের সব গঠনগত এলিমেণ্টসগুলো একটি মূল এলিমেন্টের ভিতর মুড়িয়ে নেই–আর সেটা হচ্ছে গ্রীড কণ্টেইনার। আমি এখানে <div class="container"></div> ব্যবহার করছি। 

এবার কিছু মৌলিক গ্রীড স্টাইল যোগ করিঃ

এখানে আমরা যা বর্ণনা করছি তা হচ্ছে, কনটেইনারটি display: grid; হবে, এবং এটার একটি ভগ্ন ইউনিটসহ একক কলাম থাকবে (এই সময়ে এটার খুব বেশী প্রয়োজন নেই, কিন্তু আমরা এটাকে নিখুঁত করতে এটা যোগ করেছি) এবং সব গ্রীড আইটেমের মাঝখানে 10px শূন্যস্থান থাকবে। 

বিষয়টা আরও একটু পরিস্কার করে তুলতে, এরপর আমরা বেশ কিছু ভিজুয়াল স্টাইল প্রয়োগ করবোঃ

এটিকে রেস্পন্সিভ করুন

চলুন একটি মিডিয়া কুয়েরি যোগ করি, তাই যখন "viewport" টি একটি  নির্দিষ্ট আকারের হবে (ধরা যাক 600px) তখন লেআউটটিও পরিবর্তিত হবে। 

এখন, বড় স্ক্রিণে, গ্রিড ডিক্লারেশন পরিবর্তিত হয়ে হবে grid-template-columns: repeat(4, 1fr);। এটা আমাদেরকে একই প্রস্থের চারটি কলাম দিবে, তারপর, আমাদের প্রত্যেকটি গঠনগত উপাদানের জন্য আমরা কি পরিমাণ প্রসস্থতা চাই, তা নির্ধারণ করবো।  headernav, এবং footer সবগুলোই span 4( অর্থাৎ চার কলাম জুড়ে থাকবে) যখন section এলিমেন্টটি শুধুমাত্র তিন কলাম জুড়ে থাকবে, aside এর জন্য একটি কলাম আমরা ছেড়ে যাবো যা আপনাআপনিই পূরণ হবে। 

অবশেষে, ন্যাভিগেশনের পথ পরিবর্তন করতে কিছু স্টাইল:

এখানে আমরা এ পর্যন্ত যা যা করেছি তার ফলাফল দেখানো হলোঃ

অফ-ক্যানভাসের ঝুঁকি নেয়া

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

অন্য আরেকটি মিডিয়া কুয়েরি শুরু করি। আমাদের ইতিমধ্যেই min-width কুয়েরি আছে, কিন্তু এখন আমরা উপাদানগুলো max-width এর উপর ভিত্তি করে স্টাইল করতে চাই। যতক্ষন না আমাদের ভিউপোর্ট 600px পর্যন্ত পৌছাচ্ছে, ততক্ষন আমরা আমাদের ন্যাভিগেশনটিকে off-canvas এ রাখতে চাইঃ

আমরা ন্যাভিগেশনটিকে একটি স্থির প্রস্থ দিতে যাচ্ছি, এবং এটাকে বাম পাশে এমনভাবে পজিশনিং করবো যাতে এটি সম্পূর্ণ ঢেকে যায়। আমরা পজিশন fixed ও ব্যবহার করবো, যদিও আপনি absolute ও ব্যবহার করতে পারেন, আপনি ন্যাভিগেশনটিকে উইন্ডোর সাথে সাথে স্ক্রল করাতে চান কি চান না তার উপর এটা নির্ভর করে। 

আপনি একইসাথে transition রুলটি দেখতে পারেন, যা কিছু টগল কন্ট্রোল তৈরি করার পরই কার্যকর করা হবে। 

কিভাবে টগল করবেন

আমাদের ন্যাভিগেশনটি অদৃশ্য করে দেয়ার পর, তা প্রয়োজন অনুযায়ী ফিরিয়ে আনার জন্য আমাদের বেশ কিছু কন্ট্রোল প্রয়োজন। চলুন তা বের করার জন্য একটি লিঙ্ক যোগ করা যাক, এবং বন্ধ করার জন্য আরও একটি লিঙ্ক যুক্ত করা যাক।  

এবার এটাকে header -এ যুক্ত করিঃ

এবং এটাকে nav এ যুক্ত করিঃ

আমাদের ন্যাভিগেশনের লিঙ্কটি বড় স্ক্রিনে প্রদর্শিত হউক তা আমরা চাই না, তাই এখন আমরা .toggle এলিমেণ্টটিকে min-width মিডিয়া কুয়েরির মধ্যে লুকিয়ে ফেলবো। 

:target সুডো কোড

উপরের লিঙ্ক গুলোর জন্য গুরুত্বপূর্ণ হচ্ছে একটি "fragment identifier" এর উপস্থিতি (এটা হচ্ছে href লিঙ্কের ভিতরের #nav)।নির্দিষ্ট উপাদানগুলো পেইজের মধ্যে সরাসরি চালিত করার জন্য এই শনাক্তকারী উপাদানগুলো বিভিন্ন ব্রাউজারের দ্বারা ব্যবহৃত হয়ে থাকে।   এক্ষেত্রে, আমরা টার্গেট করবো এমন কিছু এলিমেণ্ট যা id “nav”এর সঙ্গে মিলে যায়, এবং যখন আমরা এটা টার্গেট করবো, একই সাথে আমরা এটা :target সুডো বা নকল ক্লাস দিয়ে স্টাইল করে নিবো। এখানে কোনও জাভাস্ক্রিপ্টের প্রয়োজন নেই!

নিন্মলিখিত কোডগুলো max-width মিডিয়া কুয়েরিতে যোগ করে নিনঃ

এটুকুই! এটাই আমাদের টগল।

এখানে কাঙ্ক্ষিত রেজাল্টটি দেখানো হলোঃ 

এটা কিভাবে কাজ করছে তা বোঝার জন্য, আপনি একই সাথে পূর্ণ পেইজ ডেমো টি দেখে নিতে পারেন। 

পরিশিষ্ট

এবং আমরা সম্পন্ন করেছি! আমি ন্যূনতম স্টাইল বজায় রেখেছি এবং তাই এটা সেইভাবেই হয়েছে, কিন্তু চাইলে আপনি আবার শুরু থেকে তৈরি করতে পারেন এবং যেভাবে চান সেভাবে তৈরি করে নিতে পারেন। 

আপনি চাইলে JavaScript টগলও তৈরি করে নিতে পারেন, এখানে :target এর পরিবর্তে, বাকি সব কিছুই আছে যা থেকে আপনি এটি কার্যকর করে নিতে পারেন। 

আমি আশা করি আপনি এই ছোট গ্রীড অনুশীলনটি উপভোগ করেছেন, আরও বেশী টিউটোরিয়াল আসার অপেক্ষায় থাকুন!

উপকারী কিছু রিসোর্স

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.