সিএসএস গ্রিড

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

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

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

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

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

    চিলড্রেন

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

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

    display: grid;
  • ইনলাইন লেভেল গ্রিড

    display: inline-grid;
  • সাব-গ্রিড

    display: subgrid;

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

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

    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;

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

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

    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;

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

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

    grid-row-gap: 1px;
  • কলামে ফাঁকা জায়গা

    grid-column-gap: 9px;
  • দুইটা শর্টকাটে

    grid-gap: 1px 9px;
  • একই জায়গা সারি ও কলামে শর্টকাটে

    grid-gap: 6px;

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

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

    justify-items: start;
  • শেষের দিকে অ্যালাইনমেন্ট সেট করা

    justify-items: end;
  • মাঝখানে অ্যালাইনমেন্ট সেট করা

    justify-items: center;
  • ছড়িয়ে দেওয়া (ডিফল্ট)

    justify-items: stretch;

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

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

    align-items: start;
  • শেষের দিকে অ্যালাইনমেন্ট সেট করা

    align-items: end;
  • মাঝখানে অ্যালাইনমেন্ট সেট করা

    align-items: center;
  • (ডিফল্ট) ছড়িয়ে দেওয়া

    align-items: stretch;

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

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

    justify-content: start;
  • শেষের দিকে সেট করা

    justify-content: end;
  • মাঝখানে সেট করা

    justify-content: center;
  • ছড়িয়ে দেওয়া

    justify-content: stretch;
  • আইটেমের চারদিকে স্পেস ছড়িয়ে দেওয়া

    justify-content: space-around;
  • আইটেমের মধ্যবর্তী স্পেস ছড়িয়ে দেওয়া

    justify-content: space-between;
  • আইটেমের মধ্যে সমান্তরালভাবে স্পেস ছড়িয়ে দেওয়া

    justify-content: space-evenly;

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

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

    align-content: start;
  • শেষের দিকে সেট করা

    align-content: end;
  • মাঝখানে সেট করা

    align-content: center;
  • ছড়িয়ে দেওয়া

    align-content: stretch;
  • আইটেমের চারদিকে স্পেস ছড়িয়ে দেওয়া

    align-content: space-around;
  • আইটেমের মধ্যবর্তী স্পেস ছড়িয়ে দেওয়া

    align-content: space-between;
  • আইটেমের মধ্যে সমান্তরালভাবে স্পেস ছড়িয়ে দেওয়া

    align-content: space-evenly;

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

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

    #grid-auto-flow: row;
  • প্রত্যেকটা কলাম পূর্ণ করে আইটেম রাখা

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

    grid-auto-flow: dense;

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

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

    grid-column-start: 1;
  • কলামের শেষ সেট করা

    grid-column-end: 3;
  • কলামের ব্যপ্তি সেট করা

    grid-column-start: span 3;
  • শর্টকাটে

    grid-column: 2 / 3
  • ব্যপ্তিসহ শর্টকাটে

    grid-column: 2 / span 2

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

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

    grid-row-start: 1;
  • সারির শেষ সেট করা

    grid-row-end: 3;
  • সারির ব্যপ্তি সেট করা

    grid-row-start: span 3;
  • শর্টকাট

    grid-row: 1 / 3;
  • ব্যপ্তিসহ শর্টকাট

    grid-row: 1 / span 3;

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

Link
  • শুরুর দিকে

    justify-self: start;
  • শেষের দিকে

    justify-self: end;
  • মাঝখানে

    justify-self: center;
  • (ডিফল্ট) ছড়িয়ে দেওয়া

    justify-self: stretch;

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

Link
  • শুরুর দিকে

    align-self: start;
  • শেষের দিকে

    align-self: end;
  • মাঝখানে

    align-self: center;
  • (ডিফল্ট) ছড়িয়ে দেওয়া

    align-self: stretch;