آترین عباسیان
آترین عباسیان
خواندن ۵ دقیقه·۳ سال پیش

انواع واحدهای اندازه گیری در CSS

اگر با زبان CSS آشنایی داشته باشید، حتما می دانید که بعضی از ویژگی های این زبان مقداری رو به عنوان اندازه ی طولی آن ویژگی می پذیرند. ویژگی هایی مثل height , width , padding , margin , font-size و... . برای این اندازه ها واحدهای مختلفی در نظر گرفته شده که امروز می خواهیم در این مقاله در مورد انواع مختلف واحدهای اندازه گیری در CSS صحبت کنیم.




تقسیم بندی کلی واحدهای اندازه گیری یا CSS Units

واحدهای اندازه گیری در CSS به دو بخش کلی تقسیم می شوند.

1- واحدهای اندازه گیری مطلق یا Absolute Lengths :

واحدهای اندازه گیری مطلق یک مقدار ثابت دارند. یعنی عددی که همراه واحد مربوطه می آید، دقیقا همان اندازه ای است که در صفحه وب ظاهر می شود. واحدهای اندازه گیری مطلق برای استفاده در صفحات وب خیلی توصیه نمی شوند و در صورت نیاز بایستی به مقدار کم استفاده شوند، زیرا اینگونه واحدها برای هماهنگ شدن از نظر اندازه در دستگاه ها با رزولوشن های مختلف چندان مناسب نیستند. اما می توانند جهت لایه بندی صفحه پرینت همچون چاپ بنرهای تبلیغاتی و… مناسب واقع شوند.

واحد های مطلق عبارتند از:

  • پیکسل (px)
  • نقطه یا پوینت (pt)
  • پیکا (pc)
  • سانتی متر (cm)
  • میلی متر (mm)
  • اینچ (in)


حال به تعریف هر کدام از این واحدها می‌پردازیم :

واحد px یا پیکسل : در بین واحدهای اندازه گیری مطلق، واحد اندازه گیری px کاربرد متداول تری دارد. به صورت پیشفرض، اندازه پیکسل ها در دستگاه های مختلف می‌تواند متفاوت باشد، اما CSS این مشکل را با در نظر گرفتن اندازه یک پیکسل در دستگاهی با تراکم پیکسل 96DPI (نقطه در اینچ) در نظر گرفته است. بدین ترتیب، با توجه به نامتغیر بودن واحد اینچ، ابعاد یک پیکسل در تمامی دستگاه ها یکسان خواهد بود.

1px = 1/96 in

واحد pt یا نقطه : واحد نقطه، شباهت بسیاری به واحد پیکسل دارد. این واحد، ثابت و نامتغیر است و در تمامی دستگاه ها به یک اندازه ظاهر می‌شود. تفاوت واحد نقطه و پیکسل، تنها در اندازه آن هاست.

1pt = 1/72 in

واحد pc یا پیکا : واحد پیکا، واحدی است که به اندازه px و pt استفاده نمی‌شود. اندازه آن هم یک مقدار نامتغیر است.

1pc = 1/6 in

واحد های اینچ، میلی متر و سانتی متر : این واحد ها، واحد هایی هستند که همگی آن ها را می شناسیم و در واقع با این واحد ها بزرگ شدیم. از این واحد ها، به اندازه واحد های قبلی استفاده نمی‌شود، چون کاربردشان در مسائل دیگه‌ای است.

1 in = 2.54 cm = 25.4 mm


2- واحدهای اندازه گیری نسبی یا Relative Lengths :

واحدهای اندازه گیری نسبی را برای هر تگ HTML نسبت به یک تگ HTML دیگر و یا نسبت به واحد اندازه گیری دیگر تعیین می کنند. به عبارتی دیگر واحد های نسبی، واحد هایی هستند که اندازه ی ثابتی ندارند و بر اساس اندازه های دیگر در صفحه وب سایت ما تعریف می‌شوند.

مهم ترین این واحد ها، عبارتند از:

  • percent (%)
  • vw - vh
  • em
  • rem

تعریف هر کدام :

واحد % یا درصد : این واحد، عمومی ترین واحد مستقلی هست که در CSS مورد استفاده قرار می‌گیرد.

یک عنصر div با کد زیر رو فرض کنید :

div { width: 90%; }

این عنصر، همواره دارای عرضی برابر با نود درصد عرض عنصر والد خود خواهد بود. چه در صفحه دسکتاپ، چه در صفحه تبلت و چه در صفحه تلفن همراه. در صورت تغییر کردن عرض عنصر والد، عرض عنصر div هم به تناسب تغییر خواهد کرد، اما همیشه نود درصد عنصر والد خودش خواهد ماند.


واحد های vw و vh : این واحد ها، مخفف و کوتاه شده عبارات viewport width و viewport height محسوب می‌شوند. viewport، به قسمتی از صفحه وب سایت که جلوی ما قرار دارد و ما آن را میبینیم اطلاق می‌شود. این واحد ها، مشابه واحد درصد عمل می‌کنند با این تفاوت که اندازه آن ها به اندازه عنصر والد بستگی ندارد بلکه مستقیما به طول و عرض viewport ما بستگی دارد. به کد زیر توجه کنید:

div {    width: 40vw; }

کد بالا، بیانگر این است که عرض عنصر div، در هر دستگاه و صفحه نمایشی، همواره باید چهل درصد عرض viewport باشد. مشابه vw که عرض عنصر را بر حسب درصدی از عرض viewport تعیین می‌کند، vh هم ارتفاع عنصر را بر حسب درصدی از ارتفاع viewport تعریف می‌ نماید.


واحد em : این واحد، تغییرات خود را بر حسب سایز فونت عنصر والد انجام می‌دهد. برای درک بهتر این واحد، به کد زیر توجه کنید:

کد HTML :

<div class=&quotparent&quot> <div class=&quotchild&quot></div> </div>

کد CSS :

div .parent { font-size: 16px; } div .child{ width: 3em; }

واحد em، همواره به عنوان شاخصی از سایز فونت عنصر والد عمل می‌کند. بر اساس کد بالا، عرض عنصر child سه برابر سایز فونت عنصر والد یا ۴۸ پیکسل خواهد بود.


واحد rem : این واحد، مشابه واحد em عمل می‌کند. با این تفاوت که از سایز فونت عنصر والد تاثیر نمی‌گیرد، بلکه از سایز فونت خود عنصر HTML تاثیر می‌پذیرد. به همین دلیل، به این واحد rem یا root em (مربوط به عنصر ریشه وب سایت یا HTML ) گفته می‌شود. به کد زیر توجه کنید:

کد HTML :

<div class=&quotparent&quot> <div class=&quotchild&quot></div> </div>

کد CSS :

* { font-size: 20px; } div .parent{ font-size: 16px; } div .child{ width: 3rem; }

بر خلاف واحد em، توسط واحد rem، عرض عنصر child به اندازه ۶۰ پیکسل تنظیم خواهد شد (سه برابر سایز فونت عنصر root).




نکات تکمیلی در مورد واحد های اندازه گیری نسبی زبان CSS

1- بهترین واحدهای اندازه گیری نسبی جهت طراحی وب سایت های ریسپانسیو ، em و rem هستند.

2- واحدهای اندازه گیری vmax ، vh ، vw و vmin به عنوان واحدهای نسبی وابسته به viewport هستند.

3- واحدهای vmax ، vh ، vw و vmin در طراحی سایت های مقیاس پذیر یا واکنشگرا موثر خواهد بود.

نکته : واحد های اندازه گیری em ، px و rem به عنوان بهترین واحدهای اندازه گیری در طراحی سایت واکنشگرا هستند.
نکات مهم : 1- هرگز بین عدد و واحد اندازه گیری CSS فاصله نگذارید، چرا که یک خطای سینتکسی خواهد بود. به عنوان مثال مقادیر 5 em و یا 20 % که بین عدد و واحد اندازه گیری فاصله افتاده اشتباه است و حالت صحیح آن 5em و %20 است.
2- در صورتی که مقدار 0 را برای ویژگی CSS مربوطه در نظر گرفتید، نیاز به استفاده از CSS Units یا واحدهای اندازه گیری ندارید.
3- در برخی ویژگی های CSS شما اجازه استفاده از اندازه های منفی یا negative را دارید. ولی در برخی ویژگی های دیگر CSS اجازه استفاده از اندازه های منفی یا negative را ندارید.


واحد های اندازه گیریواحد های اندازه گیری cssسی اس اسcssطراحی سایت
طراح رابط و تجربه کاربری ( UI/UX )
شاید از این پست‌ها خوشتان بیاید