সীমানা

CSS পডকাস্ট - 016: বর্ডারস

বক্স মডেল মডিউলে, আমরা বক্স মডেলের প্রতিটি বিভাগকে বর্ণনা করার জন্য একটি ফ্রেম সাদৃশ্য বিবেচনা করেছি।

একে অপরের পাশে তিনটি ছবির ফ্রেম। মাঝের ফ্রেমের উপরে বক্স মডেলের অংশগুলি রয়েছে

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

সীমান্ত বৈশিষ্ট্য

পৃথক border বৈশিষ্ট্য একটি সীমানা বিভিন্ন অংশ শৈলী একটি উপায় প্রদান করে.

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 1

উৎস

শৈলী

একটি সীমানা প্রদর্শিত হওয়ার জন্য, আপনাকে border-style সংজ্ঞায়িত করতে হবে। বেছে নেওয়ার জন্য কয়েকটি বিকল্প রয়েছে:

ridge , inset , outset এবং groove শৈলী ব্যবহার করার সময়, বৈসাদৃশ্য এবং গভীরতা প্রদান করার জন্য ব্রাউজারটি দ্বিতীয় দেখানো রঙের জন্য সীমানা রঙকে গাঢ় করবে। এই আচরণ ব্রাউজারগুলির মধ্যে পরিবর্তিত হতে পারে, বিশেষ করে black রঙের মতো গাঢ় রঙের জন্য। ক্রোমে, এই বর্ডার স্টাইলগুলি শক্ত বলে মনে হবে এবং ফায়ারফক্সে, সেগুলিকে হালকা করে তারপর একটি গাঢ় দ্বিতীয় রঙ প্রদান করা হবে।

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

ক্রোম, ফায়ারফক্স এবং সাফারিতে বর্ডার ডেমো যা সীমানাগুলি কীভাবে প্রদর্শিত হয় তার মধ্যে সূক্ষ্ম পার্থক্য প্রদর্শন করে
ক্রোম, ফায়ারফক্স এবং সাফারিতে প্রদর্শিত সীমানা।

আপনার বাক্সের প্রতিটি পাশে সীমানা শৈলী সেট করতে, আপনি border-top-style , border-right-style , border-left-style এবং border-bottom-style ব্যবহার করতে পারেন।

শর্টহ্যান্ড

margin এবং padding মতো, আপনি একটি ঘোষণায় আপনার সীমানার সমস্ত অংশ সংজ্ঞায়িত করতে border শর্টহ্যান্ড সম্পত্তি ব্যবহার করতে পারেন।

.my-element {
    border: 1px solid red;
}

border শর্টহ্যান্ডে মানগুলির ক্রম হল border-width , border-style এবং তারপরে, border-color

রঙ

আপনি আপনার বাক্সের চারপাশে বা border-color দিয়ে প্রতিটি পৃথক পাশে রঙ সেট করতে পারেন। ডিফল্টরূপে, এটি বাক্সের বর্তমান পাঠ্য রঙ ব্যবহার করে: currentColor । এর মানে হল যে আপনি যদি শুধুমাত্র সীমানা বৈশিষ্ট্য ঘোষণা করেন, যেমন প্রস্থ, রঙটি সেই গণনা করা মান হবে যদি না আপনি স্পষ্টভাবে এটি সেট করেন।

.my-element {
    color: blue;
    border: solid; /* Will be a blue border */
}

.my-element {
    color: blue;
    border: solid yellow;
}

আপনার বাক্সের প্রতিটি পাশে একটি সীমানা রঙ সেট করতে, border-top-color , border-right-color , border-left-color এবং border-bottom-color ব্যবহার করুন।

প্রস্থ

একটি সীমানার প্রস্থ হল রেখাটি কতটা পুরু এবং border-width দ্বারা নিয়ন্ত্রিত হয়। ডিফল্ট সীমানা প্রস্থ medium । যদিও আপনি একটি শৈলী সংজ্ঞায়িত না করা পর্যন্ত এটি দৃশ্যমান হবে না। আপনি অন্যান্য নামযুক্ত প্রস্থ যেমন thin এবং thick ব্যবহার করতে পারেন।

border-width বৈশিষ্ট্যগুলি একটি দৈর্ঘ্যের একক যেমন px , em , rem বা % গ্রহণ করে। আপনার বাক্সের প্রতিটি পাশে সীমানা প্রস্থ সেট করতে, border-top-width , border-right-width , border-left-width এবং border-bottom-width ব্যবহার করুন।

যৌক্তিক বৈশিষ্ট্য

লজিক্যাল প্রোপার্টি মডিউলে আপনি আবিষ্কার করেছেন কিভাবে ব্লক ফ্লো এবং ইনলাইন প্রবাহ বোঝাতে হয়, উপরের, ডান, নীচে বা বাম দিকের পরিবর্তে।

সীমানা সহ আপনারও এই ক্ষমতা রয়েছে:

.my-element {
    border: 2px dotted;
    border-inline-end: 2px solid red;
}

এই উদাহরণে, .my-element সমস্ত দিক 2px , ডটেড বর্ডার যা বর্তমান পাঠ্যের রঙ হিসাবে সংজ্ঞায়িত করা হয়েছে। inline-end বর্ডারটি তারপর 2px , কঠিন এবং লাল হিসাবে সংজ্ঞায়িত করা হয়। এর মানে হল বাম-থেকে-ডান ভাষায় — ইংরেজির মতো — লাল বর্ডারটি বাক্সের ডানদিকে থাকবে। ডান-থেকে-বাম ভাষাতে - যেমন আরবি - বাক্সের বাম দিকে লাল সীমানা থাকবে।

বর্ডারে লজিক্যাল বৈশিষ্ট্যের জন্য ব্রাউজার সমর্থন বৈচিত্র্যময়, তাই ব্যবহার করার আগে নিশ্চিত করুন যে আপনি সমর্থন চেক করেছেন।

সীমানা ব্যাসার্ধ

একটি বাক্স বৃত্তাকার কোণ দিতে border-radius বৈশিষ্ট্য ব্যবহার করুন.

.my-element {
    border-radius: 1em;
}

এই শর্টহ্যান্ডটি আপনার বাক্সের প্রতিটি কোণে একটি সামঞ্জস্যপূর্ণ সীমানা যোগ করে। অন্যান্য সীমানা বৈশিষ্ট্যগুলির মতো, আপনি border-top-left-radius , border-top-right-radius , border-bottom-right-radius এবং border-bottom-left-radius সহ প্রতিটি পাশের সীমানা ব্যাসার্ধ সংজ্ঞায়িত করতে পারেন।

আপনি শর্টহ্যান্ডে প্রতিটি কোণার ব্যাসার্ধও নির্দিষ্ট করতে পারেন, যা ক্রম অনুসরণ করে: উপরে বাম, উপরে ডান, নীচে ডান তারপর নীচে বাম।

.my-element {
    border-radius: 1em 2em 3em 4em;
}

একটি কোণার জন্য একটি একক মান সংজ্ঞায়িত করে, আপনি অন্য সংক্ষিপ্ত হাত ব্যবহার করছেন কারণ একটি সীমানা ব্যাসার্ধ দুটি অংশে বিভক্ত: উল্লম্ব এবং অনুভূমিক দিক। এর মানে হল যে আপনি যখন border-top-left-radius: 1em , আপনি উপরের-বাম- শীর্ষ ব্যাসার্ধ এবং উপরের-বাম- বাম ব্যাসার্ধ সেট করছেন।

আপনি এই মত প্রতি কোণে উভয় বৈশিষ্ট্য সংজ্ঞায়িত করতে পারেন:

.my-element {
    border-top-left-radius: 1em 2em;
}

এটি 1em এর একটি border-top-left-top মান এবং 2em এর একটি border-top-left-left মান যোগ করে। এটি ডিফল্ট বৃত্তাকার ব্যাসার্ধের পরিবর্তে উপরের বাম সীমানা ব্যাসার্ধকে একটি উপবৃত্তাকার ব্যাসার্ধে রূপান্তর করে।

আপনি মান মানের পরে উপবৃত্তাকার মানগুলিকে সংজ্ঞায়িত করতে a / ব্যবহার করে border-radius সংক্ষেপে এই মানগুলি সংজ্ঞায়িত করতে পারেন। এটি আপনাকে সৃজনশীল হতে এবং কিছু জটিল আকার তৈরি করতে সক্ষম করে।

.my-element {
    border: 2px solid;
  border-radius: 95px 155px 148px 103px / 48px 95px 130px 203px;
}

সীমান্তের ছবি

আপনাকে শুধু CSS-এ স্ট্রোক-ভিত্তিক বর্ডার ব্যবহার করতে হবে না। আপনি border-image ব্যবহার করে যেকোনো ধরনের ছবিও ব্যবহার করতে পারেন। এই শর্টহ্যান্ড প্রপার্টিটি আপনাকে সোর্স ইমেজ সেট করতে দেয়, কিভাবে সেই ইমেজটি স্লাইস করা হয়, ইমেজের প্রস্থ, সীমানাটি প্রান্ত থেকে কতদূর শুরু হয় এবং কিভাবে এটি পুনরাবৃত্তি করা উচিত।

.my-element {
  border-image-source: url(https://assets.codepen.io/174183/border-image-frame.jpg);
  border-image-slice: 61 58 51 48;
  border-image-width: 20px 20px 20px 20px;
  border-image-outset: 0px 0px 0px 0px;
  border-image-repeat: stretch stretch;
}

border-image-width বৈশিষ্ট্যটি border-width মতো: আপনি কীভাবে আপনার সীমানা চিত্রের প্রস্থ সেট করেন। border-image-outset প্রপার্টি আপনাকে আপনার বর্ডার ইমেজ এবং এটির চারপাশে মোড়ানো বাক্সের মধ্যে দূরত্ব সেট করতে দেয়।

border-image-source

border-image-source (সীমানা ছবির উৎস) যেকোন বৈধ ছবির জন্য একটি url হতে পারে, যার মধ্যে CSS গ্রেডিয়েন্ট রয়েছে।

.my-element {
    border-image-source: url('path/to/image.png');
}

.my-element {
    border-image-source: linear-gradient(to bottom, #000, #fff);
}

border-image-slice

border-image-slice প্রপার্টি হল একটি দরকারী প্রপার্টি যা আপনাকে 4টি স্প্লিট লাইন দিয়ে তৈরি একটি ইমেজকে 9টি অংশে ভাগ করতে দেয়। এটি margin শর্টহ্যান্ডের মতো কাজ করে যেখানে আপনি উপরের, ডান, নীচে এবং বাম অফসেট মান সংজ্ঞায়িত করেন।

.my-element {
    border-image: url('image.jpg');
    border-image-slice: 61 58 51 48;
}

নীল রেখা সহ দেখানো চারটি স্লাইস সহ ডেমোতে ব্যবহৃত চিত্রটি

অফসেট মান সংজ্ঞায়িত করে, আপনার কাছে এখন চিত্রের 9টি বিভাগ রয়েছে: 4টি কোণ, 4টি প্রান্ত এবং একটি মধ্যম বিভাগ। কোণগুলি বর্ডার ইমেজ সহ উপাদানটির কোণে প্রয়োগ করা হয়। প্রান্তগুলি সেই উপাদানটির প্রান্তগুলিতে প্রয়োগ করা হয়। border-image-repeat প্রোপার্টি সংজ্ঞায়িত করে যে কীভাবে এই প্রান্তগুলি তাদের জায়গা পূরণ করে এবং border-image-width সম্পত্তি স্লাইসের আকার নিয়ন্ত্রণ করে।

সবশেষে, fill কীওয়ার্ড নির্ধারণ করে যে মাঝামাঝি অংশটি, স্লাইসিং দ্বারা বাম, উপাদানটির ব্যাকগ্রাউন্ড ইমেজ হিসাবে ব্যবহার করা হবে কি না।

border-image-repeat

border-image-repeat হল আপনি কিভাবে সিএসএসকে নির্দেশ দেন যেভাবে আপনি আপনার বর্ডার ইমেজ পুনরাবৃত্তি করতে চান। এটি background-repeat মতোই কাজ করে।

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

আপনার উপলব্ধি পরীক্ষা করুন

সীমানা সম্পর্কে আপনার জ্ঞান পরীক্ষা করুন

ডিফল্ট বর্ডার কালার কোনটি?

black
আবার চেষ্টা কর!
white
আবার চেষ্টা কর!
currentColor
এই বিশেষ CSS মান গণনা করা text-color মানকে উপস্থাপন করবে এবং এটি ডিফল্ট বর্ডার রঙ।
historicColor
এই গঠিত হয়. আবার চেষ্টা কর!
.my-element {
  border: solid hotpink;
}

একটি সীমানার ডিফল্ট প্রস্থ কত?

1px
আবার চেষ্টা কর!
medium
🎉
solid
এটি একটি border-style মান, border-width মান নয়।

border-inline: 1px solid হবে...

বাম এবং ডানে সীমানা রাখুন (ল্যাটিন লেআউটে)।
🎉
উপরে এবং নীচে সীমানা রাখুন (ল্যাটিন লেআউটে)।
ইংরেজির মতো ল্যাটিন লেআউটে, border-block উপরের এবং নীচে হবে।
ভিতরে সীমানা রাখুন।
আবার চেষ্টা কর!
প্রথম লাইনে সীমানা রাখুন।
আবার চেষ্টা কর!