সিএসএস গ্রিড

ডেভসংকেত

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

ব্যাসিক ধারণা

গ্রিড অ্যাপ্লাই করা হয় সিএসএস প্রপার্টি display দিয়ে

display: grid;

যে ইলিমেন্ট এ গ্রিড প্রপার্টি অ্যাপ্লাই করা হয় সেটা গ্রিড কন্টেইনার। কন্টেইনারে অ্যাপ্লাই করা যাবে এমন সিএসএস প্রপার্টিগুলো কন্টেইনার দিয়ে চিহ্নিত করা হয়েছে

কন্টেইনার

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

চিলড্রেন

কন্টেইনার - গ্রিড ফরম্যাট

ব্লক লেভেল গ্রিড

display: grid;

ইনলাইন লেভেল গ্রিড

display: inline-grid;

সাব-গ্রিড

display: subgrid;

কন্টেইনার - গ্রিড টেমপ্লেট(কলাম)

গ্রিডের কলাম ডিফাইন করা

grid-template-columns: <লম্বা(%,fr,px)> ... | <নাম> <লম্বা(%,fr,px)> ...;

গ্রিড কলাম উদাহরণ(পিক্সেল দিয়ে)

grid-template-columns: 12px 12px 12px;

গ্রিড কলাম উদাহরণ(ফাংশন দিয়ে)

grid-template-columns: repeat(3, 12px);

গ্রিড কলাম উদাহরণ(অটো)

grid-template-columns: 8px auto 8px;

গ্রিড কলাম উদাহরণ(পার্সেন্টিজ)

grid-template-columns: 22% 22% auto;

কন্টেইনার - গ্রিড টেমপ্লেট(সারি)

গ্রিডের সারি ডিফাইন করা

grid-template-rows: <লম্বা(%,fr,px)> ... | <নাম> <লম্বা(%,fr,px)> ...;

গ্রিড সারি উদাহরণ(পিক্সেল দিয়ে)

grid-template-rows: 12px 12px 12px;

গ্রিড সারি উদাহরণ(ফাংশন দিয়ে)

grid-template-rows: repeat(3, 12px);

গ্রিড সারি উদাহরণ(অটো)

grid-template-rows: 8px auto 8px;

গ্রিড সারি উদাহরণ(পার্সেন্টিজ)

grid-template-rows: 22% 22% auto;

কন্টেইনার - ফাঁকা জায়গা

সারিতে ফাঁকা জায়গা

grid-row-gap: 1px;

কলামে ফাঁকা জায়গা

grid-column-gap: 9px;

দুইটা শর্টকাটে

grid-gap: 1px 9px;

একই জায়গা সারি ও কলামে শর্টকাটে

grid-gap: 6px;

কন্টেইনার - গ্রিড আইটেম সারিতে অ্যালাইনমেন্ট

শুরুতে অ্যালাইনমেন্ট সেট করা

justify-items: start;

শেষের দিকে অ্যালাইনমেন্ট সেট করা

justify-items: end;

মাঝখানে অ্যালাইনমেন্ট সেট করা

justify-items: center;

ছড়িয়ে দেওয়া (ডিফল্ট)

justify-items: stretch;

কন্টেইনার - গ্রিড আইটেম কলামে অ্যালাইনমেন্ট

শুরুর দিকে অ্যালাইনমেন্ট সেট করা

align-items: start;

শেষের দিকে অ্যালাইনমেন্ট সেট করা

align-items: end;

মাঝখানে অ্যালাইনমেন্ট সেট করা

align-items: center;

(ডিফল্ট) ছড়িয়ে দেওয়া

align-items: stretch;

কন্টেইনার - গ্রিড কন্টেন্ট সারিতে অ্যালাইনমেন্ট

শুরুর দিকে সেট করা

justify-content: start;

শেষের দিকে সেট করা

justify-content: end;

মাঝখানে সেট করা

justify-content: center;

ছড়িয়ে দেওয়া

justify-content: stretch;

আইটেমের চারদিকে স্পেস ছড়িয়ে দেওয়া

justify-content: space-around;

আইটেমের মধ্যবর্তী স্পেস ছড়িয়ে দেওয়া

justify-content: space-between;

আইটেমের মধ্যে সমান্তরালভাবে স্পেস ছড়িয়ে দেওয়া

justify-content: space-evenly;

কন্টেইনার - গ্রিড কন্টেন্ট কলামে অ্যালাইনমেন্ট

শুরুর দিকে সেট করা

align-content: start;

শেষের দিকে সেট করা

align-content: end;

মাঝখানে সেট করা

align-content: center;

ছড়িয়ে দেওয়া

align-content: stretch;

আইটেমের চারদিকে স্পেস ছড়িয়ে দেওয়া

align-content: space-around;

আইটেমের মধ্যবর্তী স্পেস ছড়িয়ে দেওয়া

align-content: space-between;

আইটেমের মধ্যে সমান্তরালভাবে স্পেস ছড়িয়ে দেওয়া

align-content: space-evenly;

কন্টেইনার - অটো প্লেস অ্যালগরিদম

প্রত্যেকটা সারি পূর্ণ করে আইটেম রাখা

#grid-auto-flow: row;

প্রত্যেকটা কলাম পূর্ণ করে আইটেম রাখা

grid-auto-flow: column;

ডেন্স প্যাকিং অ্যালগরিদম ব্যবহার করে ছোটো আইটেম থাকা সত্ত্বেও বড় আইটেমের কারণে সৃষ্ট ফাঁকা যায়গা অর্ডার ভেঙ্গে ভরাট করা

grid-auto-flow: dense;

চিলড্রেন - গ্রিড কলাম

কলামের শুরু সেট করা

grid-column-start: 1;

কলামের শেষ সেট করা

grid-column-end: 3;

কলামের ব্যপ্তি সেট করা

grid-column-start: span 3;

শর্টকাটে

grid-column: 2 / 3

ব্যপ্তিসহ শর্টকাটে

grid-column: 2 / span 2

চিলড্রেন - গ্রিড সারি

সারির শুরু সেট করা

grid-row-start: 1;

সারির শেষ সেট করা

grid-row-end: 3;

সারির ব্যপ্তি সেট করা

grid-row-start: span 3;

শর্টকাট

grid-row: 1 / 3;

ব্যপ্তিসহ শর্টকাট

grid-row: 1 / span 3;

চিলড্রেন - সারিতে নিজের অ্যালাইনমেন্ট

শুরুর দিকে

justify-self: start;

শেষের দিকে

justify-self: end;

মাঝখানে

justify-self: center;

(ডিফল্ট) ছড়িয়ে দেওয়া

justify-self: stretch;

চিলড্রেন - কলামে নিজের অ্যালাইনমেন্ট

শুরুর দিকে

align-self: start;

শেষের দিকে

align-self: end;

মাঝখানে

align-self: center;

(ডিফল্ট) ছড়িয়ে দেওয়া

align-self: stretch;
ডেভসংকেত

বাংলা চিটশিটের ভান্ডার

devsonket.com

প্রিন্ট করুন