جلسه ۰۵ – selector در CSS
در جلسهی گذشته، ساختاربندی و اجزای تشکیلدهندهی کد CSS رو خلاصه وار معرفی کردیم.
در این جلسه، اونها رو به صورت مفصل بررسی میکنیم و یاد میگیریم!
منطق کدهای CSS
قبل از هرچیزی، باید منطق استفاده از دستورات CSS رو متوجه بشیم. منطقش بسیار سادست. با یک سوال بیاین شروع کنیم:
چطور یک انسان رو توصیف میکنیم؟
خب مثلا یک دوستی مثل بهرام، بینی قشنگی داره! چطور این موضوع رو توصیف میکنیم؟ مسلما با جمله ی زیر:
بهرام، بینی قشنگی داره
طبق فرم کلیای که برای ساختار کدهای CSS گفته شد، میتونیم جمله ی بالا رو به این فرم بنویسیم:
- Bahram{ nose: beautiful; }
در اینجا، کلمه “Bahram” یک انتخابگر یا selector هست. چون میگه ویژگی ها متعلق به چه کسی یا چیزی هستن.
کلمه “nose” یک ویژگی یا property از بهرام هست. یعنی شکل بینی بهرام.
و در نهایت کلمه “beautiful” یک مقدار یا value برای بینی بهرام هست. مقداری که میتونه کلمات زیبا، نازیبا و غیره رو در به داشته باشه.
در CSS هم دقیقا با اینطور منطقی، چه بسا ساده تر، سر و کار داریم! مراحل کار به شکل زیره:
- یک عنصر از صفحه رو انتخاب کن.
- ویژگی عنصر رو (قیافه اون رو! ) با مقادیر مختلف تغییر بده.
مرحله اول با استفاده از انتخابگر ها انجام میگیره. برای مثال، در کد زیر، ما عناصر h1 رو در صفحه انتخاب میکنیم و چهره مورد نظرمون رو در {…} وارد میکنیم. عنصر متناسب با اطلاعات نوشته شده توسط ما، تغییر میکنه.
- h1{ … }
حالا انتخابگر ها، فقط نام عناصر نیستن، بلکه میتونن انواع مختلفی داشته باشن.
ویژگی ها و چهره ی یک عنصر
حالا میون {…} چی باید قرار بدیم؟ چطور چهره ی عنصر رو مشخص کنیم؟ بسیار سادست، ما در CSS ویژگی ها و به تناسب با اون ویژگی ها، مقادیر مختلفی داریم. برای مثال، میخوایم رنگ عنصر h1 که انتخاب کردیم، قرمز باشه:
- h1 { color : red ; }
این کد بیان میکنه، رنگ تمام متنهایی که داخلh1ها هستن، به رنگ قرمز تغییر کنه.
حالا سه نکته رو با هم بررسی کنیم:
۱. ما میتونیم به هرتعداد که میخوایم، به انتخابگر ویژگی اختصاص بدیم:
h1 { color: red ; font-size: 10px ; text-align: center ; }
۲. عموما برای راحتی کدنویسی، بهتر هست که کدها رو در خطوط جداگانه بنویسیم، یعنی:
h1{ color: red; font-size: 10px; text-align: center; }
۳. یک عنصر، نمیتونه ویژگی تکراری داشته باشه، برای مثال، کد زیر اشتباهه:
div { color: blue; color: black; }
حالا چند مثال رو با هم بررسی کنیم:
p { color: black; background-color: blue; }
تمام پاراگراف ها در صفحه، به رنگ مشکی ظاهر بشن و رنگ پسزمینه اون ها، آبی باشه.
span { font-family: IranSansWeb; opacity: 0.8; }
عناصر span در صفحه، دارای فونت IranSansWeb و شفافیت 0.8 باشند.
انواع selector در CSS
- عناصر
- کلاس ها
- آیدی ها
- انتخابگر کلی
- انتخابکنندههای گروهی ( در جلسات آینده یاد خواهیم گرفت )
- انتخابکنندههای پیشرفته ( در جلسات آینده یاد خواهیم گرفت )
عناصر
تا اینجا یاد گرفتیم که میتونیم نام خود عناصر رو به جای selector یا انتخابگر قرار داده و توسط دستورات اونها رو تغییر بدیم. مانند:
h1 { color: red ; }
که باعث میشه متن درون عنصر h1 به رنگ قرمز باشه.
بحث جدیدی که در مورد نه تنها عناصر، بلکه بهطور کلی در مورد انتخابگرها باید یاد بگیریم، بحث روابط ” فرزندی و خانوادگی ” هست!
برای یادگیری این بحث، نیازمند تسلط کافی و مناسب در HTML هستیم. همونطور که میدونیم، کدهای HTML با هم دارای رابطه فرزند و خانواده هستن. نکته این هست:
” اگر به عنصری،یک سری دستورات CSS اعمال شود، به فرزندان آن عنصر هم همان دستورات CSS اعمال میشود “
کد زیر رو در نظر بگیرید.
urdon co css urdon co html urdon co javascript
همونطور که مشاهده میشه، عناصر p، فرزند عنصر div به حساب میان. فرض کنیم کد CSS ما به شکل زیر باشه:
div { color: blue; }
انتخاب گر ها در css
از تکنیک فرزند خانواده در CSS، در آینده به وفور استفاده میکنید.
حالا سوالی که پیش میاد این هست: اگه ما ۵ پاراگراف داشته باشیم و فقط بخوایم به پاراگراف اول و سوم، رنگ قرمز رو اضافه کنیم، از چه کدی باید استفاده کنیم؟
این مشکل، با کلاسها رفع میشه!
کلاس ها
کلاس ها زمانی به کار میرن که بخوایم به عناصر معدودی، دستورات CSS رو مرتبط کنیم. روش استفاده از کلاس ها به ترتیب زیر هست:
- در فایل HTML یک کلاس با نام دلخواه، برای عناصر موردنظر، تعریف میکنیم.
- در فایل CSS، قبل از نام کلاس یک نقطه ” . ” گذاشته و خصوصیات رو برای اون مینویسیم.
برای مثال:
کد در فایل HTML
urdon co css classes
کد در فایل CSS
.class-name{ color: yellow; }
خصوصیات ذکر شده در کد CSS تنها به عناصری اعمال میشن که کلاس “class-name” رو دارا هستن.
یه مثال دیگه:
فایل HTML:
فایل CSS:
.special { background-color: yellow ; }
کلاس ها در انتخابگر هاآیدی ها
نحوهی استفاده از آیدیها در HTML و CSS به فرم زیر هست:
- در فایل HTML، برای عنصر موردنظر یک آیدی دلخواه انتخاب می کنیم.
- در فایل CSS، قبل از نام آیدی، هشتگ ( # ) قرار داده و ویژگیها رو برای عنصر مورد نظر تعریف میکنیم.
مثال:
کد HTML:
Mizfa Id tutorial
کد CSS:
#id-name{ color: yellow; }
تقریبا میشه گفت که آیدیها شباهت بسیاری به کلاسها دارن. اما تفاوتهای مهمی هم دارن که اون هارو در جلسه آینده بررسی میکنیم.
انتخابگر کلی
انتخابگر کلی، انتخابگری هست که میتونه تمام عناصر موجود در صفحه رو با یک ویژگی معین تغییر بده. این انتخابگر با علامت * مشخص میشه.
به طور مثال در کد زیر، ما میگیم که فونت تمام نوشته های درون صفحه، باید b nazanin باشه:
*{ font-family: b nazanin; }
جمع بندی
در این مقاله به صورت کامل با انتخابگر ها آشنا شدیم، در جلسه آینده در رابطه با کلاس ها و آی دی ها و نحوه معرفی آن ها در CSS آشنا خواهید شد.
اگه نکته، پیشنهاد و انتقادی در رابطه با آموزشها دارین، خیلی خیلی خوشحال میشیم که اون رو با ما درمیون بزارین🙂❤
نویسنده : father phury