چرا باید از مدل رنگ HSL در CSS استفاده کنیم؟


۱۸ مهر ۱۳۹۹
HSL چیست؟

هنگامی که شما در حال طراحی محصول هستید، مهم نیست که از CSS، Sass، کامپوننت‌های از پیش استایل‌دهی شده، ماژول‌های CSS یا هرچیز دیگری استفاده می‌کنید، شاید اغلب برای تعریف رنگ‌ها از HEX یا RGB استفاده کنید اما قابلیتی وجود دارد که توسط آن می‌توانید این کار را بهتر انجام دهید و ما در این مقاله قصد داریم مدل رنگ HSL را به شما معرفی کنیم.

HSL چیست؟

HSL یک مدل نمایش رنگ کاربرپسندانه (user-friendly) است که شما را قادر می‌سازد بدون نیاز به دانش تخصصی، حدس بزنید که رنگ‌های خاص چگونه به‌نظر می‌رسند. HSL مخفف عبارت‌های Hue (گرمای رنگ)، Saturation (اشباع رنگ) و Lightness (درخشندگی یا روشنایی رنگ) است. Hue یک رنگدانه خالص و بدون هرگونه ته‌رنگ و سایه‌ای بوده که رنگ‌های اصلی این مدل نمایش رنگ را در بر می‌گیرد. Saturation نشان‌دهنده میزان خلوص یا اشباع رنگ بوده و Lightness شدت روشنایی یک رنگ را تعیین می‌کند.

چگونه کد رنگ را در مدل نمایش رنگ HSL بخوانیم؟

برای خواندن کد رنگ در مدل نمایش رنگ HSL، ابتدا باید hue را که در بخش ابتدایی کد رنگ قرار دارد، مشاهده کنید. hue به‌صورت درجه‌ای اعلام می‌شود و در محدوده صفر تا ۳۶۰ درجه قابل تنظیم است. بر اساس چرخه رنگ hue، زاویه صفر درجه نشان‌دهنده رنگ قرمز، زاویه ۱۲۰ درجه نشان‌دهنده رنگ سبز و زاویه ۲۴۰ درجه به رنگ آبی اشاره می‌کند.

چرخه رنگ hsl

قسمت بعدی کد شامل saturation است و بر اساس درصد بیان می‌شود. صفر درصد نشان‌دهنده رنگ خاکستری بوده و ۱۰۰٪ بیشترین شدت رنگ را نشان می‌دهد. اما آخرین موردی که باید خوانده شود، مربوط به Lightness یا همان روشنایی رنگ است. صفر درصد روشنایی بیانگر رنگ سیاه است. شدت روشنایی ۵۰٪ یک وضعیت خنثی بوده و شدت روشنایی ۱۰۰٪، رنگ سفید است. در درجه‌بندی رنگ‌ها، ۳۸۰ درجه درست مانند ۲۰ درجه بوده و منفی ۱۲۰ درجه نیز درست مانند ۲۴۰ درجه است.

ویژگی‌های برجسته HSL

یکی از بزرگترین و برجسته‌ترین مزایای مدل نمایش رنگ HSL، قابلیت خوانایی آن است. در واقع شما نیازی ندارید که زمان زیادی را صرف یادگیری روش خواندن این مدل رنگ کنید و سختی‌های کد HEX را به خود به‌همراه ندارد. همچنین تصور رنگ‌ها در این مدل بسیار ساده‌تر از مدل RGB است.

ایجاد متغیرهای مدل رنگ HSL در CSS

همان‌طور که در مثال زیر مشاهده می‌کنید، ساخت طیف رنگ‌ها در مدل HSL با استفاده از متغیرهای CSS بسیار ساده و آسان است.

:root {
  --primary-color-h: 156;
  --primary-color-s: 50%;
  --primary-color-l: 50%;
  --primary-color: hsl(var(--primary-color-h), var(--primary-color-s), var(--primary-color-l));
  --primary-color--light: hsl(var(--primary-color-h), var(--primary-color-s), calc(var(--primary-color-l) + var(--lighten)));
  --primary-color--dark: hsl(var(--primary-color-h), var(--primary-color-s), calc(var(--primary-color-l) + var(--darken)));
  --secondary-color: hsl(calc(var(--primary-color-h) + 180), var(--primary-color-s), var( --primary-color-l));
  --lighten: 15%;
  --darken: -15%;
}

برای تنظیم رنگ ثانویه، hue را برابر ۱۸۰ قرار دادیم؛ چرا که اکنون رنگ‌های اولیه و ثانویه مکمل یکدیگر هستند. این تعریف، درست همان نظریه پایه رنگ‌ها است.

این روز‌ها تم‌های تیره بسیار محبوب و پرطرفدار شده‌اند. اما چگونه می‌توانید میان تم‌های روشن و تیره تغییر وضعیت دهید؟ همان‌طور که می‌دانید، شما می‌توانید با Sass، یا حتی ابزار pure CSS با استفاده از کلاس dark-theme جاوااسکریپت، به‌خوبی این کار را انجام دهید. اما نقطه ضعف این راهکار چیست؟ نقطه ضعف این رویکرد، افزایش بیش از حد کدهای CSS است.

بنابراین به‌جای راهکار بالا، می‌توانید رویکرد زیر را پیاده‌سازی کنید.

.hero {
  background: #ffffff;
  color: #333;
}

.dark-theme .hero {
  background: #3d3d3d;
  color: #e5e5e5;
}

شما می‌توانید به‌صورت پایه از قطعه کدهایی مشابه کد بالا، استفاده کنید. البته این قطعه کد یک نمونه بسیار ساده است؛ اما آن‌چه قصد داشتیم در این کد به شما نشان دهیم، انعطاف‌پذیری کار با رنگ‌های HSL است. این قابلیت، یک ویژگی بسیار برجسته و حائز اهمیت در مدل نمایش رنگ HSL است که فرصت استفاده از خواص هر یک از رنگ‌ها را به‌صورت جداگانه برای شما فراهم می‌کند.

:root {
  --primary-color-h: 156;
  --primary-color-s: 50%;
  --primary-color-l: 50%;
  --darken: 0%;
  --primary-color: hsl(var(--primary-color-h), var( --primary-color-s), calc(var(--primary-color-l) + var(--darken)));
}
const button = document.querySelector("#switcher");
const root = document.documentElement;
const body = document.querySelector("body");

button.addEventListener("click", () => {
  body.classList.contains("dark-theme") ? setLightTheme() : setDarkTheme();
  body.classList.toggle("dark-theme");
});

const setDarkTheme = () => {
  root.style.setProperty("--darken", "-90%");
};

const setLightTheme = () => {
  root.style.setProperty("--darken", "0%");
};

قابلیت خوانایی

تصور کنید یک دکمه (button) در مقابل شما قرار دارد که یک متن به رنگ سفید با پس‌زمینه‌ی سفید، به‌صورت rgb(30, 144, 255) وجود دارد. اکنون فرض کنید که قصد دارید رنگ این پس‌زمینه سفید رنگ را کمی تیره‌تر انتخاب کنید و کنتراست آن را افزایش بدهید.

چه رنگی را باید انتخاب کنید؟

الف) rgb(30, 193, 255)

ب) rgb(107, 181, 255)

ج) rgb(107, 181, 255)

د) rgb(107, 181, 255)

سوال دشواری است! این‌طور نیست؟

اکنون بیایید که با مدل نمایش رنگ HSL پرسش را دوباره مطرح کنیم. رنگ پایه hsl(210, 100%, 56%) را در نظر بگیرید.

کدام رنگ مناسب‌ترین انتخاب برای پس‌زمینه این کلید است؟

الف) hsl(197, 100%, 56%)

ب) hsl(210, 100%, 71%)

ج) hsl(315, 68%, 42%)

د) hsl(210, 100%, 41%)

اکنون احتمال تشخیص پاسخ صحیح بسیار بیشتر است. همان‌طور که مشاهده می‌کنید، پاسخ صحیح گزینه «د» است.

طیف رنگ‌ها

اساسا تمامی کارهایی که با استفاده از Sass قابل انجام است را نیز می‌توانید با استفاده از CSS انجام دهید. آیا قصد دارید که یکی از رنگ‌های موجود در صفحه را روشن‌تر کنید؟ برای این‌کار تنها کافی‌ست که عددی را به تنظیمات روشنایی رنگ، اضافه کنید. آیا نیاز دارید که تنظیمات آن رنگ را تیره‌تر کنید؟ عدد مربوط به روشنایی رنگ را در تنظیمات آن کاهش دهید. برای مثال شما با استفاده از Sass می‌توانید hue را برابر ۱۸۰ قرار دهید. همچنین در CSS می‌توانید با استفاده از ماژول Triada عدد ۱۲۰ را به رنگ اولیه و عدد ۲۴۰ را به رنگ ثانویه اضافه کنید. علاوه‌براین برای رنگ‌های آنالوگ نیز می‌توانید از طریق متغیرهای درجه‌ای اقدام کنید.

برای امتحان این قابلیت می‌توانید این مثال را در codepen را بررسی کنید.

:root {
  --primary-color-h: 156;
  --primary-color-s: 50%;
  --primary-color-l: 50%;
  --primary-color: hsl(var(—primary-color-h), var(--primary-color-s), var(--primary-color-l));
  
  /* lighten */
  --primary-color--light: hsl(var(--primary-color-h), var(--primary-color-s), calc(var(--primary-color-l) + 15%));

  /* darken */ 
  --primary-color--dark: hsl(var(--primary-color-h), var(--primary-color-s), calc(var(--primary-color-l) - 15%));
  
  /* complement */
  --primary-color--complement: hsl(calc(var(--primary-color-h) + 180), var(--primary-color-s), var(--primary-color-l));

  /* triad */ 
  --primary-color--triada-1: hsl(calc(var(--primary-color-h) + 120), var(--primary-color-s), var(--primary-color-l));
  --primary-color--triada-2: hsl(calc(var(--primary-color-h) + 240), var(--primary-color-s), var(--primary-color-l));

  /* analogous */
  --degree: 15;
  --primary-color--analogous-1: hsl( 
    calc(var(--primary-color-h) + var(--degree)), 
    var(--primary-color-s), 
    var(--primary-color-l)
  );
  --primary-color--analogous-2: hsl( 
    calc(var(--primary-color-h) - var(--degree)), 
    var(--primary-color-s), 
    var(--primary-color-l)
  );
}

چگونگی بررسی کد HSL برای RGB یا HEX

ابزار Chrome DevTools بسیار شگفت‌انگیز و کارآمد است. با استفاده از این ابزار تنها کافی‌ست که رنگ مورد نیاز المنت مدنظرتان را بررسی و سبک مناسبی برای ترکیب رنگ اصلی، رنگ پس‌زمینه و غیره بیابید؛ سپس درحالی‌که کلید shift را نگه داشته‌اید، باید بر روی مربع تعیین رنگ (color picker) کلیک کنید. به این ترتیب رنگ انتخابی شما به ترتیب به مدل HEX، مدل RGB و در پایان مدل HSL تبدیل می‌شود. این قابلیت از اهمیت بسیار بالایی برخوردار است.

اگر نمی‌خواهید که برای یافتن یک ترکیب رنگی مناسب وقت خود را هدر دهید، می‌توانید ابزار DevTools گوگل را باز کرده و در یک element.style، یک color جدید ایجاد کنید. سپس هر رنگی را که می‌خواهید، می‌توانید انتخاب کنید. پس از آن باید color picker را باز کرده و بر روی رنگی که می‌خواهید مقدار عددی آن را بدانید، کلیک کنید.

transparency مدل نمایش رنگ HSL

قابلیت transparency یا میزان وضوح و شفافیت در مدل نمایش رنگ HSL، درست مانند مدل RGB است. برای تعیین شفافیت در این مدل می‌توانید مشابه کدی که در ادامه مشاهده می‌کنید، در کانال alpha مقادیری از صفر تا یک، وارد کنید.

hsla(220, 70%, 45%, 0.3)

همان‌طور که می‌بینید، مدل نمایش رنگ HSL‌ بسیار جذاب و کارآمد است. این مدل نمایش رنگ، جایگزین بسیار عالی است که کلیه فرایند را بسیار ملموس‌تر و قابل‌درک‌تر می‌کند. همچنین از دیدگاه کاربر، مدل HSL بسیار ساده‌تر است. برای استفاده از HSL شما نیازی ندارید که مهارت و دانش زیادی در زمینه رنگ‌ها و نمایش آن‌ها داشته باشید؛ شما حتی می‌توانید نحوه نمایش رنگ‌های خاص را نیز با مدل HSL متصور شوید. بنابراین چرا باید از این مدل رنگ در پروژه‌های‌تان بی‌بهره باشید؟!

منبع: https://tsh.io/blog/why-should-you-use-hsl-color-representation-in-css

برچسب‌ها:

خدمات رایگان لیارا

۲.۵ گیگابایت فضای ذخیره‌سازی ابری رایگان

۲.۵ گیگابایت Object Storage سازگار با پروتکل S3 با دیسک‌های SSD به‌صورت رایگان دریافت کنید.

هاست رایگان برای دیتابیس‌

دیتابیس‌های MariaDB، PostgreSQL و Redis را فقط با یک کلیک و به‌صورت رایگان تهیه کنید.

سرویس DNS رایگان

به سادگی دامنه‌تان را اضافه کنید و به صورت رایگان رکورد‌های آن را مدیریت کنید.

۱۰۰ هزار تومان اعتبار اولیه

بعد از ثبت نام در لیارا مبلغ ۱۰۰ هزار تومان اعتبار هدیه دریافت می‌کنید که با توجه به ساعتی بودن هزینه سرویس‌ها، می‌توانید تمامی خدمات پولی را برای چندین هفته رایگان استفاده کنید.

ارسال ۱۰۰ ایمیل تراکنشی رایگان در هر ماه

در سرویس ایمیل لیارا شما می‌توانید تا ۱۰۰ ایمیل رایگان در هر ماه ارسال کنید و فقط برای بیش از آن هزینه پرداخت کنید. (به‌همراه دسترسی SMTP)

هاست رایگان برای انواع وبسایت

تفاوتی ندارد برای وبسایت خود از Node استفاده می‌کنید یا Laravel و Django، در لیارا می‌توانید به صورت کاملا رایگان آن را میزبانی کنید.

توسعه‌دهندگان درباره‌ی ما چه می‌گویند

تجربه کار باliara_cloud@امروز خیلی خوب بود. یکی از سرویس هام رو منتقل کردم روش و راضیم. انقد سریع و جذاب کارم راه افتادم اصن باورم نمیشد! برعکس سرویس های PaaS دیگه با اون همه پیچیدگیشون. دمتون گرم
...

MohammadReza
liara testimonial
keikaavousi

بعد از بسته شدن @fandoghpaas و ناراحتی همه‌مون از اینکه یه سرویس خوب و صادق نمی‌تونه از پس هزینه‌ها بر بیاد، سرویسم رو منتقل کردم به پاس لیارا (https://liara.ir @liara_cloud) . تجربه راحت و خوب. تفاوت‌هایی داشت که کمی کار می‌خواست ولی تا الان کاملا راضی.

jadi
liara testimonial
jadi

یه خسته نباشید باید به تصمیمliara_cloud@بگم،
بعد از چندین روز سرکله زدن با سرویس های مشابه بالاخره تصمیم گرفتم لیارا رو امتحان کنم و باور نمیشه ۱۰ دقیقه بیشتر وقت نبرد،
دمتون گرم.

Arch
liara testimonial
EbadiDev

واسه سرویس PaaS با اختلاف لیارا بهترین رابط کاربری داره و یکی از مزیت‌های سرویس دیتابیس‌شون اینه که خودشون به صورت دوره‌ای بکآپ میگیرن.
...

Ali Najafi
liara testimonial
me_ali_najafi

یکی از کارهای خوبی که جدیداً میکنم اینه که یه دیتابیس روی لیارا میسازم و به پروژه وصل میکنم اینطوری هم خونه و هم محل کار دیتابیس بروز رو دارم و راحت میتونم ادامه بدم کار روliara_cloud@

Navid
liara testimonial
1navid

عاشقliara_cloud@شدم درسته در حد AWS نیست ولی خب تجربه خوبی واسه پروژه های داخل ایران ارائه میده، میتونم رو CD هم اجراش کنم

Amir H Shekari
liara testimonial
vanenshi

همراه شما هستیم

در خصوص سفارش یا استفاده از سرویس‌ها سوالی دارید؟
تلفن واحد فروش:
۰۲۵-۳۳۵۵۷۶۱۹ (روزهای کاری ۹ الی ۱۷)
تلفن واحد فروش: ۳۳۵۵۷۶۱۹-۰۲۵ (روزهای کاری ۹ الی ۱۷)