ألوان في CSS - شرح مبسّط
يونيو 26, 2025ألوان في CSS - شرح مبسّط
النهارده هنتكلم عن الألوان في CSS: ازاي بنحددها، وخصوصًا الطرق الحديثة زي lab() وoklch().
1. يعني إيه لون؟
مفيش حاجة اسمها "لون" في العالم الفيزيائي. اللون هو تجربة بصرية بتتكون في المخ بعد ما العين تستقبل موجات الضوء.
2. Color spaces – مجالات الألوان
المجالات دي خرائط ثلاثية الأبعاد بتمثل الألوان. مثال:
sRGB: المجال الافتراضي في أغلب الشاشات.CIELABوOklab: مجالات بتدي نتائج ألوان أكثر انتظامًا للعين.color(display‑p3 ...): بتدعم ألوان أوسع على الشاشات الحديثة.
3. Color models – أنماط الألوان
زي RGB أو HSL، اللي هما بس طريقه رياضية لتمثيل اللون. بدون المجال (color space)، الوظيفة بتبقى مش واضحة.
4. Color gamut – مجال الألوان المتاح
هو مدى الألوان اللي المجال يقدر يمثلها. لو الشاشة مش قادرة على لون معين، بنقول عليه out-of-gamut.
5. Color functions – دوال الألوان في CSS
rgb(), hsl(), hwb(): للألوان التقليدية في sRGB.lab(), lch(): للألوان في مجال CIELAB.oklab(), oklch(): للألوان في مجال Oklab.color(), color-mix(): للوصول لأي مجال زي display‑p3، rec2020، وغيره.
مثال كود:
.box-srgb {
background: rgb(255, 100, 50);
}
.box-oklab {
background: oklab(70% 0.05 -0.10);
}
.box-display-p3 {
background: color(display-p3 1 0.2 0.3);
}
ملخص سريع (TL;DR)
- Color space = المجال اللي بيمثل الألوان.
- Color model = تمثيل رقمي بدون مجال.
- Color gamut = مدى الألوان المتاحة.
- الدوال الحديثة بتخلينا نستخدم مجالات ألوان حديثة على الويب.
المدونة
يوليو 07, 2025
إتقان التحقق الشرطي في Laravel 12 في Laravel 12، نظام التحقق (validation) قوي جدًا، وميزة التحقق الشرطي بتخليك تتحكم في القوانين بتاعتك ب...
يوليو 01, 2025
حلل كود Laravel باستخدام Laravel Introspect لو بتعمل Refactor كبير أو بتبني أدوات Dev، Laravel Introspect بيسمحلك تستعلم عن الكود: فيوز، مودلز، رو...
يونيو 17, 2025
React Labs: View Transitions وActivity المنشور اتكتب يوم 23 أبريل 2025 من Ricky Hanlon. في React Labs النهارده بيقدّموا ميزتين تجريبيّتين مودرن...
يوليو 06, 2025
📘 شرح تفصيلي لتحديثات ECMAScript 2025 جميع مميزات ECMAScript 2025، مع أمثلة عملية وفهم ليه الميزة دي مهمة لأي مبرمج واجهة أمامية. ١. مجموعات مسما...
يوليو 24, 2025
🧠 يعني إيه Dynamic Import؟ الديناميـك إمبورت ببساطة هو إنك تحمّل ملف أو موديول JavaScript "وقت الحاجة بس" مش من أول الصفحة. الميزة دي بتقلل حجم ال...
يوليو 02, 2025
تجاوز $fillable بأمان باستخدام forceFill() في Laravel جربت تستخدم create() في Laravel ولاقيت إن حقول زي role أو status مش بتتحفظ؟ ده بسبب حماية Larav...