استفاده از کلاس و id در طراحی صفحات با CSS

  • سلکتور کلاس

با استفاده از کلاس می توانیم برای یک تگ HTML استایلهای متفاوتی را تعریف کنیم. برای نمونه فرض کنیم می خواهیم در صفحه دو نوع پاراگراف داشته باشیم: یکی با متن مشکی و دیگری با متن قرمز. برای مشخص کردن این دو نوع پاراگراف می توانیم از سلکتور کلاس استفاده کنیم. ابتدا استایل را به صورت زیر می نویسیم:

p.black {color: black}
p.red {color:red}

در مرحله بعد باید برای هر پاراگرافی که می خواهیم به رنگ مشکی باشد از شناسه "class="black در تگ <p> استفاده کنیم و برای پاراگراف قرمز از شناسه "class="red. البته نام کلاسها اختیاری است ولی بهتر است آنها را طوری انتخاب کنید که مفهوم داشته باشند تا وقتی که حجم استایل شما بیشتر شد به گنگ نباشد. در مثال زیر می توانید کد مربوط به نوشتن دو پاراگراف بالا را در متن HTML ملاحظه کنید:

<p class="black">این متنی است که به رنگ مشکی نمایش داده می شود</p>
<p class="red">این متن به رنگ قرمز نمایش داده می شود.</p>

نکته : شما می توانید بیش از یک کلاس برای یک تگ HTML تعریف کنید اما برای این کار نباید دو بار از شناسه class استفاده کرد. بلکه باید در یک شناسه class نام دو کلاس مورد نظر را با یک فاصله بین آنها وارد کرد. برای مثال برای پاراگراف زیر از دو کلاس فرضی red و center استفاده شده است:

<p class="red center">این متن پاراگرافی است که تحت تأثیر دو کلاس red و center قرار دارد</p>

در نوشتن استایل می توان از نوشتن نام تگ در سلکتور کلاس چشم پوشی کرد. در این صورت ویژگیهای تعریف شده در آن کلاس بر هر تگ HTML که از کلاس مربوطه در شناسه class آن استفاده شده باشد اثر می گذارد. برای مثال در کلاس زیر ویژگی وسط چین را تعریف می کنیم و از نام تگ در سلکتور کلاس استفاده نمی کنیم:

.center {text-align: center}

اکنون برای هر تگی که احتیاج به وسط چین داشته باشد می توانیم از کلاس بالا استفاده کنیم. به چند نمونه در زیر توجه کنید:

<p class="center">متن این پاراگراف به صورت وسط چین نمایش داده می شود</p>
<div class="center">متن این قسمت به صورت وسط چین نمایش داده می شود</div>
<h2 class="center">متن این سرفصل به صورت وسط چین نمایش داده می شود</h2>

تذکر : هیچ وقت نام کلاس را با یک عدد شروع نکنید چون در این صورت مرورگرهای Mozilla و Firefox نمی توانند از آن کلاس استفاده کنند.

ما می توانیم از سلکتور کلاس برای تگی که حاوی شناسه class است استفاده کنیم که در قسمتهای قبلی در این مورد توضیح داده شد. علاوه بر این می توانیم از ویژگیهای تعریف شده در سلکتور کلاس برای تگهایی که در یک تگ محتوی شناسه class قرار دارند نیز استفاده کنیم. مثلا برای لینکهایی که در یک DIV قرار دارند و برای DIV کلاس تعریف شده است. برای این کار در نوشتن استایل مربوطه باید پس از نقطه که مشخص کننده سلکتور کلاس است نام کلاس را وارد کنیم و پس از وارد کردن یک فضای خالی نام تگی که می خواهیم ویژگیهای بر روی آن اعمال شود. به مثال زیر توجه کنید:

در این مثال از استایل زیر در استفاده می کنیم:

.test { border: #F00 1px double }
.test a { color: green }
.test a:hover { border: yellow 2px solid }

کد HTML زیر برای این مثال مورد استفاده قرار می گیرد:

<div class="test">
<a href="#">لینک آزمایشی شماره 1</a>
</div>
<a href="#">لینک آزمایشی شماره 2</a>

می توانید نتیجه را در اینجا مشاهده کنید:

لینک آزمایشی شماره 2

همانطور که در مثال بالا می بینید خواص لینک آزمایشی شماره 1 تحت تأثیر استایل مورد استفاده برای تگ DIV قرار دارد ولی لینک آزمایشی شماره 2 مانند سایر لینکهای خارج از DIV نمایش داده می شود.

 


  • افزودن استایل به نوع مشخصی از عناصر

همانطور که می دانید با وجود اینکه برخی از عناصر در صفحه با هم تفاوت دارند، از یک تگ HTML برای ایجاد آنها استفاده می شود.برای مثال برخی از این عناصر را که از تگ <input> در به وجود آوردن آنها استفاده می شود می توانید در زیر مشاهده کنید:

  • <"input type="text>
    کادرهای متنی که در فرمها استفاده می شود.
  • <"input type="checkbox>
    چک باکس هم با استفاده از تگ <input> به وجود می آید.
  • <"input type="radio>
    در ساختن دکمه های رادیو هم از همان تگ استفاده می شود.
  • <"input type="button>
    این تگ در ساختن هم استفاده می شود.
  • <"input type="submit>
    برای ساختن دکمه ارسال فرم هم از تگ <input> استفاده می شود.

حالا فرض کنید ما در یک صفحه از چند نمونه از عناصر بالا استفاده کرده ایم ولی فقط می خواهیم ویژگیهای یکی از آنها را تغییر دهیم. دو روش برای این کار وجود دارد: یکی استفاده از کلاس است که در این روش اگر تعداد زیادی از عنصر مورد نظر در صفحه وجود داشته باشد باید به همان تعداد از شناسه class در تگهای آنها استفاده کنیم و ممکن است این کار باعث افزایش حجم صفحه یا موجب سختی در نوشتن کد شود. روش دوم تعریف کردن سلکتور input برای عناصر مورد نظر است که به صورت زیر انجام می گیرد:

فرض کنید می خواهیم فقط عرض کادرهای متنی را در صفحه تغییر دهیم. در صورتی که در استایل از سلکتور input به تنهایی استفاده کنیم عرض همه چک باکسها ، دکمه ارسال، دکمه های رادیو و سایر عناصری که از تگ <input> استفاده کرده اند نیز تغییر می کند. برای انجام این کار می توانید سلکتور را به صورت زیر تعریف کنیم:

input[type="text"] {
width: 200px
}

کد استایلی که در بالا نوشتیم فقط بر روی کادر های متنی که در آنها از شناسه "type="text استفاده شده است اثر می گذارد.

البته این روش ممکن است در مرورگر Internet Explorer پشتیبانی نشود اما مرورگرهای Firefox و Opera از آن پشتیبانی می کنند.

 


سلکتور id

روش دیگری که برای تعریف استایل وجود دارد استفاده از id است. شناسه id احتمالاً در آینده جایگزین شناسه name در تگهای HTML می شود بنا بر این در هرصفحه نباید بیش از یک بار از هر ID استفاده شود. اگر بیش از یک بار از یک id استفاده شود کارایی صفحه تغییری نمی کند ولی صفحه اعتبار خود را از دست می دهد. سلکتور id با علامت # مشخص می شود. با استایل زیر همه عناصر که شناسه "id="border دارند با کادری سبز رنگ نمایش داده می شوند:

#border { border: green thin solid }

برای مثال ما از استایل بالا در این صفحه استفاده کرده ایم. حالا کد زیر را وارد صفحه می کنیم:

<h3 id="border">این یک سرفصل با اندازه 3 است</h3>
<div id="border">این قسمت یک div است </div>

در قسمت زیر می توانید نتیجه کد بالا را مشاهده کنید:

این یک سرفصل با اندازه 3 است

این قسمت یک div است

همانطور که کلاس را می توانستیم برای یک عنصر مشخص تعریف کنیم در مورد id نیز می توانیم این کار را انجام دهیم. به استایل زیر توجه کنید:

p#border { border: green thin solid }

استایل بالا فقط روی پاراگرافی که شناسه "id="green در آن به کا رفته اثر می گذارد.

نکته : هرگز نام یک id را با یک عدد آغاز نکنید چون در این صورت مرورگرهای Mozilla و Firefox نمی توانند از آن استفاده کنند.


نظرات بازدید کنندگان
Wed, 20 May 2009 10:27:34 +0430 نویسنده : حسن
ممنو نم  سايت خيلي خوبي هست اميد وارم  موفق باشيد متشكرم
 
Sat, 18 Apr 2009 14:39:18 +0430 نویسنده : rama
باسلام و عرض خسته نباشید
میخواستم اگه  ممکنه بگید چطور میشه آمار سایتو به روز کرد.(update)
 
Mon, 26 Jan 2009 00:02:47 +0330 نویسنده : mohammad
مرسی
خوب بود
 
Thu, 27 Nov 2008 23:28:10 +0330 نویسنده : ایمان پوراندخت
سایتتون خوبه فقط اموزشphp  و asp  و xmlرا بزارین
 
Thu, 27 Nov 2008 23:20:43 +0330 نویسنده : ایمان
با عرض سلام سایت عالی است چند مدتی بود دنبال همچین سایتی بودم
 
Sun, 16 Nov 2008 19:13:49 +0330 نویسنده : داود
بسیار عالی
 
Sun, 09 Nov 2008 10:31:55 +0330 نویسنده : حسین بیاتی
سلام با تشکر از شما
زکات علم نشر ان می باشد به امید روزی که همه صادقانه علم خود را در اختیار دیگران قرار دهند
 
Mon, 20 Oct 2008 21:01:38 +0330 نویسنده : محمدرضا
متشکرم ، امیدوارم همیشه موفق باشید و خدا خیرتان بدهد.
 
Mon, 13 Oct 2008 00:04:53 +0330 نویسنده : بهنود
سلام
با تشکر و خسته نباشید.
از صادق هم ممنون هستم چون کامنتیش خیلی خوب بود
 
Sat, 04 Oct 2008 00:10:18 +0330 نویسنده : سعيده
سلام و عرض ادب خدمت شما
من دانشجو هستم كمك درسي  بسيار خوبي برايم بود.
متشكرم
 
Thu, 07 Aug 2008 01:51:48 +0430 نویسنده : یعقوب
با عرض سلام وخسته نباشید خدمت شما دوست گرامی.از این که دانسته های خوداتن را در اختیار دیگران قرار میدهید تشکر میکنم.
 
Fri, 06 Jun 2008 20:03:01 +0430 نویسنده : amir
mamnon az zahamateton
vali ye meghdari gonge
 
Mon, 02 Jun 2008 10:15:42 +0430 نویسنده : يونس جمشيدي
با عرض سلام .مطلالبتون خوبه ولي اين قسمتش يه مقداري گنگه.
 
Sun, 25 May 2008 09:37:25 +0430 نویسنده : darya
salam khaste nabashid.
az site khoubetounam tashakor.
migam u ham cheshetoun khorde be baghye ejazeh save kardan nemidid ghablana khoub boudid in karo mishod anjam dada vali hala...
bazam ye karish bokonid chon injouri sakhteh
 
Thu, 08 May 2008 11:03:56 +0430 نویسنده : صادق
دوست عزیز، در قسمت اول، <style> و <style/> رو جا انداختی
گرفتی که؟
با تشکر
 
Mon, 24 Mar 2008 10:03:13 +0330 نویسنده : Tom
زياد واضح نبود
 
ساعت: 10:28 - تاریخ: 17 دی 1386 نویسنده : leila
ba tashakor az araq mibinam.ali bod mamnun
 
ساعت: 09:50 - تاریخ: 1386 نویسنده : عفت
خوب بود ان شا ء الله بهتر هم میشود
 
ساعت: 09:47 - تاریخ: 1386 نویسنده : لیلی
خوب بود عزیزم
 
ساعت: 08:59 - تاریخ: 8 مهر 1386 نویسنده : امید
باسلام و عرض خسته نباشید  ،محتوای این وب سایت بسیار پربار است امیدوارم موفق باشید و مطالب جدیدتری در اختیار کاربران بگذارید با تشکر