ফাংশন

CSS পডকাস্ট - 020: ফাংশন

এখন পর্যন্ত এই কোর্সে, আপনি বেশ কয়েকটি CSS ফাংশনের সংস্পর্শে এসেছেন। গ্রিড মডিউলে, আপনাকে minmax() এবং fit-content() এর সাথে পরিচয় করিয়ে দেওয়া হয়েছে, যা আপনাকে উপাদানের আকার দিতে সাহায্য করে। রঙ মডিউলে, আপনাকে rgb() , এবং hsl() এর সাথে পরিচয় করিয়ে দেওয়া হয়েছে, যা আপনাকে রং নির্ধারণ করতে সাহায্য করে।

অন্যান্য অনেক প্রোগ্রামিং ল্যাঙ্গুয়েজের মতো, CSS-এর অনেকগুলি অন্তর্নির্মিত ফাংশন রয়েছে যা আপনি যখনই প্রয়োজন তখন অ্যাক্সেস করতে পারেন।

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

একটি ফাংশন কি?

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

উপরে বর্ণিত একটি ফাংশনের একটি চিত্র

অনেক CSS ফাংশন বিশুদ্ধ ফাংশন , যার মানে হল যে আপনি যদি তাদের মধ্যে একই আর্গুমেন্ট পাস করেন, তাহলে আপনার বাকি কোডে যা ঘটছে তা নির্বিশেষে তারা আপনাকে সবসময় একই ফলাফল দেবে। এই ফাংশনগুলি প্রায়শই আপনার CSS-এ মান পরিবর্তনের সাথে সাথে পুনরায় গণনা করবে, ভাষার অন্যান্য উপাদানের মতো, যেমন কম্পিউটেড ক্যাসকেডেড মান যেমন currentColor

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

কার্যকরী নির্বাচক

.post :is(h1, h2, h3) {
    line-height: 1.2;
}

আপনি সিউডো-ক্লাস মডিউলে কার্যকরী নির্বাচকদের সম্পর্কে শিখেছেন যা বিস্তারিত ফাংশন যেমন :is() এবং :not() । এই ফাংশনগুলিতে পাস করা আর্গুমেন্টগুলি হল CSS নির্বাচক, যেগুলি পরে মূল্যায়ন করা হয়। উপাদানগুলির সাথে মিল থাকলে, বাকি CSS নিয়ম তাদের জন্য প্রয়োগ করা হবে।

কাস্টম বৈশিষ্ট্য এবং var()

:root {
    --base-color: #ff00ff;
}

.my-element {
    background: var(--base-color);
}

একটি কাস্টম প্রপার্টি হল একটি ভেরিয়েবল যা আপনাকে আপনার CSS কোডে মান টোকেনাইজ করতে দেয়। কাস্টম বৈশিষ্ট্যগুলিও ক্যাসকেড দ্বারা প্রভাবিত হয় যার অর্থ সেগুলি প্রাসঙ্গিকভাবে ম্যানিপুলেট বা পুনরায় সংজ্ঞায়িত করা যেতে পারে। একটি কাস্টম সম্পত্তি অবশ্যই দুটি ড্যাশ ( -- ) সহ প্রিফিক্স করা উচিত এবং কেস সংবেদনশীল।

var() ফাংশনটি একটি প্রয়োজনীয় আর্গুমেন্ট নেয়: কাস্টম সম্পত্তি যা আপনি একটি মান হিসাবে ফেরত দেওয়ার চেষ্টা করছেন। উপরের স্নিপেটে, var() ফাংশনটি --base-color একটি আর্গুমেন্ট হিসাবে পাস করেছে। যদি --base-color সংজ্ঞায়িত করা হয়, তাহলে var() মান প্রদান করবে।

.my-element {
    background: var(--base-color, hotpink);
}

আপনি var() ফাংশনে একটি ফলব্যাক ঘোষণা মানও পাস করতে পারেন। এর মানে হল যদি --base-color খুঁজে পাওয়া না যায়, তাহলে পাস করা ঘোষণাটি ব্যবহার করা হবে, যা এই নমুনার ক্ষেত্রে hotpink রঙ।

ফাংশন যা একটি মান প্রদান করে

var() ফাংশন হল CSS ফাংশনগুলির মধ্যে একটি যা একটি মান প্রদান করে। attr() এবং url() এর মতো ফাংশনগুলি var() এর অনুরূপ কাঠামো অনুসরণ করে — আপনি এক বা একাধিক আর্গুমেন্ট পাস করেন এবং আপনার CSS ঘোষণার ডানদিকে ব্যবহার করেন।

a::after {
  content: attr(href);
}

এখানে attr() ফাংশনটি <a> এলিমেন্টের href অ্যাট্রিবিউটের বিষয়বস্তু গ্রহণ করছে এবং এটিকে ::after সিউডো-এলিমেন্টের content হিসেবে সেট করছে। যদি <a> উপাদানের href অ্যাট্রিবিউটের মান পরিবর্তন করা হয়, তাহলে এটি স্বয়ংক্রিয়ভাবে এই content বৈশিষ্ট্যে প্রতিফলিত হবে।

.my-element {
    background-image: url('/path/to/image.jpg');
}

url() ফাংশন একটি স্ট্রিং URL নেয় এবং ছবি, ফন্ট এবং বিষয়বস্তু লোড করতে ব্যবহৃত হয়। যদি একটি বৈধ ইউআরএল পাস না করা হয় বা ইউআরএল নির্দেশ করে এমন সংস্থান খুঁজে না পাওয়া যায়, url() ফাংশন দ্বারা কিছুই ফেরত দেওয়া হবে না।

রঙ ফাংশন

আপনি রঙ মডিউল মধ্যে রঙ ফাংশন সম্পর্কে সব শিখেছি. আপনি যদি এখনও এটি না পড়ে থাকেন তবে এটি দৃঢ়ভাবে সুপারিশ করা হয় যে আপনি এটি করবেন।

CSS-এ উপলব্ধ কিছু রঙ ফাংশন হল rgb() , rgba() , hsl() , hsla() , hwb() , lab() এবং lch() । এই সবগুলির একটি অনুরূপ ফর্ম রয়েছে যেখানে কনফিগারেশন আর্গুমেন্টগুলি পাস করা হয় এবং একটি রঙ ফেরত দেওয়া হয়।

গাণিতিক অভিব্যক্তি

অন্যান্য অনেক প্রোগ্রামিং ভাষার মতো, CSS বিভিন্ন ধরনের গণনার সাথে সহায়তা করার জন্য দরকারী গাণিতিক ফাংশন প্রদান করে।

calc()

Browser Support

  • ক্রোম: 26।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 7।

Source

calc() ফাংশনটি তার প্যারামিটার হিসাবে একটি একক গাণিতিক অভিব্যক্তি নেয়। এই গাণিতিক অভিব্যক্তিটি দৈর্ঘ্য, সংখ্যা, কোণ এবং ফ্রিকোয়েন্সির মতো ধরণের মিশ্রণ হতে পারে। ইউনিটগুলিও মিশ্রিত করা যেতে পারে।

.my-element {
    width: calc(100% - 2rem);
}

এই উদাহরণে, calc() ফাংশনটি একটি এলিমেন্টের প্রস্থকে 100% এর প্যারেন্ট এলিমেন্ট ধারণ করতে ব্যবহার করা হচ্ছে, তারপর সেই গণনা করা মান থেকে 2rem সরিয়ে দেওয়া হচ্ছে।

:root {
  --root-height: 5rem;
}

.my-element {
  width: calc(calc(10% + 2rem) * 2);
  height: calc(var(--root-height) * 3);
}

calc() ফাংশন অন্য calc() ফাংশনের ভিতরে নেস্ট করা যেতে পারে। আপনি একটি অভিব্যক্তির অংশ হিসাবে একটি var() ফাংশনে কাস্টম বৈশিষ্ট্যগুলিও পাস করতে পারেন।

min() এবং max()

Browser Support

  • ক্রোম: 79।
  • প্রান্ত: 79।
  • ফায়ারফক্স: 75।
  • সাফারি: 11.1।

Source

min() ফাংশন এক বা একাধিক পাস করা আর্গুমেন্টের ক্ষুদ্রতম গণনাকৃত মান প্রদান করে। max() ফাংশন বিপরীতটি করে: এক বা একাধিক পাস করা আর্গুমেন্টের সবচেয়ে বড় মান পান।

.my-element {
  width: min(20vw, 30rem);
  height: max(20vh, 20rem);
}

এই উদাহরণে, প্রস্থ 20vw এর মধ্যে সবচেয়ে ছোট মান হওয়া উচিত —যা ভিউপোর্ট প্রস্থের 20% —এবং 30rem । উচ্চতা 20vh - যা ভিউপোর্ট উচ্চতার 20% - এবং 20rem এর মধ্যে সবচেয়ে বড় মান হওয়া উচিত।

বাতা()

Browser Support

  • ক্রোম: 79।
  • প্রান্ত: 79।
  • ফায়ারফক্স: 75।
  • সাফারি: 13.1।

Source

clamp() ফাংশনটি তিনটি আর্গুমেন্ট নেয়: সর্বনিম্ন আকার, আদর্শ আকার এবং সর্বোচ্চ।

h1 {
  font-size: clamp(2rem, 1rem + 3vw, 3rem);
}

এই উদাহরণে, font-size ভিউপোর্টের প্রস্থের উপর ভিত্তি করে তরল হবে। স্ক্রীন জুমিংয়ে সহায়তা করার জন্য একটি rem ইউনিটে vw ইউনিট যোগ করা হয়েছে, কারণ জুম স্তর নির্বিশেষে একটি vw ইউনিট একই আকারের হবে। একটি rem ইউনিট দ্বারা গুণ করা - রুট ফন্টের আকারের উপর ভিত্তি করে - একটি আপেক্ষিক গণনা বিন্দু সহ clamp() ফাংশন প্রদান করে।

আপনি এই নিবন্ধে min() , max() , এবং clamp () ফাংশন সম্পর্কে আরও শিখতে পারেন।

আকৃতি

clip-path , offset-path এবং shape-outside CSS বৈশিষ্ট্যগুলি আপনার বাক্সটিকে দৃশ্যত ক্লিপ করতে বা চারপাশে প্রবাহিত বিষয়বস্তুর জন্য একটি আকৃতি প্রদান করতে আকারগুলি ব্যবহার করে৷

আকৃতি ফাংশন আছে যা এই উভয় বৈশিষ্ট্যের সাথে ব্যবহার করা যেতে পারে। circle() , ellipse() এবং inset() এর মতো সাধারণ আকারগুলি তাদের আকার দেওয়ার জন্য কনফিগারেশন আর্গুমেন্ট নেয়। আরও জটিল আকার, যেমন polygon() কাস্টম আকৃতি তৈরি করতে X এবং Y অক্ষ মানের কমা দ্বারা পৃথক জোড়া নেয়।

.circle {
  clip-path: circle(50%);
}

.polygon {
  clip-path: polygon(0% 0%, 100% 0%, 100% 75%, 75% 75%, 75% 100%, 50% 75%, 0% 75%);
}

polygon() মত, একটি path() ফাংশনও রয়েছে যা একটি SVG ফিল নিয়মকে একটি আর্গুমেন্ট হিসেবে নেয়। এটি অত্যন্ত জটিল আকারের জন্য অনুমতি দেয় যা একটি গ্রাফিক্স টুল যেমন ইলাস্ট্রেটর বা ইঙ্কস্কেপে আঁকা যায় এবং তারপরে আপনার CSS-এ কপি করা যায়।

রূপান্তরিত করে

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

ঘূর্ণন

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

আপনি rotate() ফাংশন ব্যবহার করে একটি উপাদান ঘোরাতে পারেন, যা একটি উপাদানকে তার কেন্দ্র অক্ষে ঘোরাতে পারে। আপনি পরিবর্তে একটি নির্দিষ্ট অক্ষে একটি উপাদান ঘোরাতে rotateX() , rotateY() এবং rotateZ() ফাংশন ব্যবহার করতে পারেন। ঘূর্ণনের মাত্রা নির্ধারণ করতে আপনি ডিগ্রি, টার্ন এবং রেডিয়ান ইউনিট পাস করতে পারেন।

.my-element {
  transform: rotateX(10deg) rotateY(10deg) rotateZ(10deg);
}

rotate3d() ফাংশনটি চারটি আর্গুমেন্ট নেয়।

Browser Support

  • ক্রোম: 12।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 10।
  • সাফারি: 4।

Source

প্রথম ৩টি আর্গুমেন্ট হল সংখ্যা, যা X, Y এবং Z স্থানাঙ্ককে সংজ্ঞায়িত করে। চতুর্থ যুক্তি হল ঘূর্ণন যা অন্যান্য ঘূর্ণন ফাংশনের মতই ডিগ্রী, কোণ এবং বাঁক গ্রহণ করে।

.my-element {
  transform: rotate3d(1, 1, 1, 10deg);
}

স্কেল

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

আপনি transform এবং scale() ফাংশন সহ একটি উপাদানের স্কেলিং পরিবর্তন করতে পারেন। ফাংশনটি একটি মান হিসাবে এক বা দুটি সংখ্যা গ্রহণ করে যা একটি ইতিবাচক বা নেতিবাচক স্কেলিং নির্ধারণ করে। আপনি যদি শুধুমাত্র একটি সংখ্যার আর্গুমেন্ট সংজ্ঞায়িত করেন, তাহলে X এবং Y অক্ষ উভয়ই একই স্কেল করা হবে এবং উভয়কে সংজ্ঞায়িত করা হল X এবং Y-এর জন্য একটি সংক্ষিপ্ত বিবরণ। ঠিক যেমন rotate() , scaleX() , scaleY() এবং scaleZ() ফাংশন রয়েছে পরিবর্তে একটি নির্দিষ্ট অক্ষের উপর একটি উপাদান স্কেল.

.my-element {
  transform: scaleX(1.2) scaleY(1.2);
}

এছাড়াও rotate ফাংশন মত, একটি scale3d() ফাংশন আছে. এটি scale() এর অনুরূপ, তবে এটি তিনটি আর্গুমেন্ট নেয়: X, Y এবং Z স্কেল ফ্যাক্টর।

অনুবাদ করুন

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

translate() ফাংশন একটি উপাদানকে স্থানান্তরিত করে যখন এটি নথির প্রবাহে তার অবস্থান বজায় রাখে। তারা আর্গুমেন্ট হিসাবে দৈর্ঘ্য এবং শতাংশ মান গ্রহণ করে। translate() ফাংশনটি X অক্ষ বরাবর একটি উপাদান অনুবাদ করে যদি একটি আর্গুমেন্ট সংজ্ঞায়িত করা হয়, এবং উভয় আর্গুমেন্ট সংজ্ঞায়িত করা হলে X এবং Y অক্ষ বরাবর একটি উপাদান অনুবাদ করে।

.my-element {
  transform: translatex(40px) translatey(25px);
}

আপনি করতে পারেন—অন্যান্য রূপান্তর ফাংশনের মতো—একটি নির্দিষ্ট অক্ষের জন্য নির্দিষ্ট ফাংশন ব্যবহার করতে পারেন, translateX , translateY এবং translateZ ব্যবহার করে। এছাড়াও আপনি translate3d ব্যবহার করতে পারেন যা আপনাকে X, Y এবং Z অনুবাদকে একটি ফাংশনে সংজ্ঞায়িত করতে দেয়।

স্কুইং

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

আপনি skew() ফাংশন ব্যবহার করে একটি উপাদানকে তিরস্কার করতে পারেন যা কোণকে আর্গুমেন্ট হিসাবে গ্রহণ করে। skew() ফাংশন translate() এর জন্য খুব অনুরূপ ভাবে কাজ করে। আপনি যদি শুধুমাত্র একটি যুক্তি সংজ্ঞায়িত করেন তবে এটি শুধুমাত্র X অক্ষকে প্রভাবিত করবে এবং যদি আপনি উভয়টি সংজ্ঞায়িত করেন তবে এটি X এবং Y অক্ষকে প্রভাবিত করবে। প্রতিটি অক্ষকে স্বাধীনভাবে প্রভাবিত করতে আপনি skewX এবং skewY ব্যবহার করতে পারেন।

.my-element {
  transform: skew(10deg);
}

দৃষ্টিকোণ

Browser Support

  • ক্রোম: 36।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

Source

পরিশেষে, আপনি perspective সম্পত্তি ব্যবহার করতে পারেন — যা বৈশিষ্ট্যের রূপান্তর পরিবারের অংশ—ব্যবহারকারী এবং Z সমতলের মধ্যে দূরত্ব পরিবর্তন করতে। এটি দূরত্বের অনুভূতি দেয় এবং আপনার ডিজাইনে ক্ষেত্রের গভীরতা তৈরি করতে ব্যবহার করা যেতে পারে।

ডেভিড ডেসান্ড্রোর এই উদাহরণটি, তাদের খুব দরকারী নিবন্ধ থেকে, দেখায় যে এটি কীভাবে ব্যবহার করা যেতে পারে, perspective-origin-x এবং perspective-origin-y বৈশিষ্ট্য সহ সত্যিকারের 3D অভিজ্ঞতা তৈরি করতে।

অ্যানিমেশন ফাংশন, গ্রেডিয়েন্ট এবং ফিল্টার

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

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

ফাংশন আপনার জ্ঞান পরীক্ষা

CSS ফাংশন কোন অক্ষর দ্বারা চিহ্নিত করা যায়?

[]
এই অক্ষরগুলি জাভাস্ক্রিপ্টের অ্যারের জন্য।
{}
এই অক্ষরগুলি সিএসএস-এ নিয়মগুলি মোড়ানো।
()
ফাংশন এই অক্ষর ব্যবহার করে আর্গুমেন্ট মোড়ানো হ্যাঁ!
::
এই অক্ষরগুলি সিএসএস-এ ছদ্ম-উপাদানের জন্য।
:
এই অক্ষরগুলি সিএসএস-এর সিউডো-ক্লাসের জন্য।

সিএসএস বিল্ট-ইন গণিত ফাংশন আছে?

সত্য
তাদের অনেক আছে, এবং আরো যোগ করা হচ্ছে চশমা এবং ব্রাউজারে!
মিথ্যা
আবার চেষ্টা করুন!

একটি calc() ফাংশন অন্য calc() এর ভিতরে স্থাপন করা যেতে পারে যেমন font-size: calc(10px + calc(5px * 3));

সত্য
🎉
মিথ্যা
আবার চেষ্টা করুন!

নিচের কোনটি CSS শেপ ফাংশন?

ellipse()
🎉
square()
আবার চেষ্টা করুন!
circle()
🎉
rect()
আবার চেষ্টা করুন!
inset()
🎉
polygon()
🎉