منحدرات

The CSS Podcast - 021: Gradients

لنفترض أنّ لديك موقعًا إلكترونيًا تريد إنشاؤه، وبجانبه في أعلى الصفحة، تظهر مقدمة تتضمّن عنوانًا وملخّصًا وزرًا. قدّم المصمّم تصميمًا يتضمّن خلفية أرجوانية لهذه المقدمة. المشكلة الوحيدة هي أنّ الخلفية تعرض لونَين من اللون الأرجواني على شكل تدرّج. كيف يتم ذلك؟

خلفية متدرّجة من الأرجواني الداكن إلى الفاتح مع عنوان وفقرة ورابط

قد تعتقد في البداية أنّك ستحتاج إلى تصدير صورة من أداة التصميم لإجراء ذلك، ولكن يمكنك استخدام linear-gradient بدلاً من ذلك.

التدرّج هو صورة ويمكن استخدامه في أي مكان يمكن فيه استخدام الصور، ولكن يتم إنشاؤه باستخدام CSS ويتكون من ألوان وأرقام وزوايا. تتيح لك تدرجات CSS إنشاء أي شيء بدءًا من تدرج سلس بين لونَين وحتى عمل فني مثير للإعجاب من خلال مزج تدرجات متعددة وتكرارها.

منحدر خطي

تنشئ الدالة linear-gradient() صورة من لونَين أو أكثر بشكل تدريجي. يأخذ هذا الدالة عدة وسيطات، ولكن في أبسط إعداداته، يمكنك تمرير بعض الألوان على النحو التالي، وسيتم تقسيمها تلقائيًا بالتساوي مع مزجها.

.my-element {
    background: linear-gradient(black, white);
}

يمكنك أيضًا تمرير زاوية أو كلمات رئيسية تمثّل زاوية. إذا اخترت استخدام الكلمات الرئيسية، حدِّد اتجاهًا بعد الكلمة الرئيسية to. وهذا يعني أنّه إذا كنت تريد تدرّجًا باللونَين الأسود والأبيض، يمتد من اليسار (أسود) إلى اليمين (أبيض)، عليك تحديد الزاوية على أنّها to right كوسيطة أولى.

.my-element {
    background: linear-gradient(to right, black, white);
}

قيمة نقطة توقف اللون التي يتم تحديدها عند توقف لون معيّن واختلاطه بالألوان المجاورة بالنسبة إلى التدرّج الذي يبدأ بدرجة داكنة من اللون الأحمر ويمتد بزاوية 45 درجة، يظهر على النحو التالي عند تغييره إلى درجة أفتح من اللون الأحمر بنسبة% 30 من حجم التدرّج:

.my-element {
    background: linear-gradient(45deg, darkred 30%, crimson);
}

يمكنك إضافة أي عدد تريده من الألوان ونقاط اللون في linear-gradient()، ويمكنك وضع تدرّجات اللون فوق بعضها البعض عن طريق الفصل بين كل تدرّج بفاصلة.

منحدر شعاعي

لإنشاء انتقال شعاعي بشكل دائري، يمكنك استخدام الدالة radial-gradient(). وهو مشابه لعنصر linear-gradient()، ولكن بدلاً من تحديد زاوية، يمكنك اختياريًا تحديد موضع وشكل نهائي. إذا حدّدت الألوان فقط، سيختار الرمز radial-gradient() تلقائيًا الموضع على أنّه center ويختار إما دائرة أو بيضاوية، استنادًا إلى حجم المربّع.

.my-element {
    background: radial-gradient(white, black);
}

يكون موضع التدرّج مشابهًا لـ background-position باستخدام الكلمات الرئيسية و/أو القيم الرقمية. يحدّد حجم التدرّج الشعاعي حجم الشكل النهائي للتدرّج (دائرة أو بيضاوية)، وسيكون تلقائيًا farthest-corner، ما يعني أنّه يتلاقى تمامًا مع أبعد زاوية من المربّع عن المركز. يمكنك أيضًا استخدام الكلمات الرئيسية التالية:

  • سيلتقي closest-corner بأقرب زاوية إلى مركز التدرج اللوني.
  • سيلتقي closest-side بجانب المربّع الأقرب إلى مركز التدرّج.
  • سينفّذ farthest-side العكس تمامًا لما يفعله closest-side.

يمكنك إضافة أي عدد تريده من نقاط اللون، تمامًا كما هو الحال مع linear-gradient. وبالمثل، يمكنك إضافة أي عدد تريده من radial-gradients.

التدرّج المخروطي

يتضمّن التدرّج المخروطي نقطة مركزية في المربّع ويبدأ من الأعلى (تلقائيًا)، ويدور في دائرة بزاوية 360 درجة.

.my-element {
    background: conic-gradient(white, black);
}

تقبل الدالة conic-gradient() وسيطات الموضع والزاوية.

تكون الزاوية تلقائيًا 0 درجة، وتبدأ من أعلى الشاشة في منتصفها. إذا ضبطت الزاوية على 45deg، سيكون ذلك في أعلى يسار الشاشة. تقبل وسيطة الزاوية أي نوع من قيم الزاوية، مثل التدرجات اللونية الخطية والشعاعية.

يكون الموضع في المنتصف تلقائيًا. كما هو الحال مع التدرّجات الشعاعية والخطية، يمكن أن يستند تحديد الموضع إلى الكلمات الرئيسية، أو يمكن تحديده باستخدام قيم رقمية.

يمكنك إضافة أي عدد تريده من نقاط اللون، كما هو الحال مع أنواع التدرجات الأخرى. من حالات الاستخدام الجيدة لهذه الميزة، مع التدرّجات المخروطية، هي عرض المخططات الدائرية باستخدام CSS.

التكرار والاختلاط

ولكل نوع من أنواع التدرجات نوع متكرر أيضًا. وهي رمزَا repeating-linear-gradient() و repeating-radial-gradient() و repeating-conic-gradient(). وهي مشابهة للدوالّ غير المتكرّرة وتستخدِم الوسيطات نفسها. الفرق هو أنّه إذا كان من الممكن تكرار التدرّج المحدّد لملء المربّع، سيتم تكراره استنادًا إلى حجمَي المربّعَين.

إذا لم يظهر لك أنّ التدرّج اللوني يتكرر، من المحتمل أنّك لم تضبط طولًا لأحد نقاط اللون. على سبيل المثال، يمكنك إنشاء خلفية مخططة باستخدام repeating-linear-gradient من خلال ضبط أطوال نقاط اللون.

.my-element {
  background: repeating-linear-gradient(
    45deg,
    red,
    red 30px,
    white 30px,
    white 60px
  );
}

يمكنك أيضًا مزج دوالّ التدرّج في background السمات، بالإضافة إلى تحديد أي عدد تريده من التدرّجات، تمامًا كما تفعل مع صورة الخلفية. على سبيل المثال، يمكنك مزج عدة تدرّجات خطية معًا، أو تدرّجَين خطيَّين مع تدرّج شعاعي.

الاستقراء ومساحات الألوان

يمكن لكل نوع من أنواع التدرجات التدرّج بين الألوان بطرق مختلفة باستخدام مساحات الألوان والمفتاح البرمجي in. يتيح لك هذا الخيار تخصيص النتائج بين نقطتَي توقف للّون في تدرج.

على سبيل المثال، يمكنك استخدام مساحة الألوان oklab لإزالة الألوان غير المشبعة في المنتصف بشكل عام وضمان تدرج أكثر أمانًا وحيوية.

.my-element {
  background: linear-gradient(in oklch, deeppink, yellow);
}

يتيح لك العرض الترويجي التالي مقارنة التدرّج اللوني نفسه مع التداخل المخصّص وبدونه. جرِّب تغيير مساحات الألوان لمعرفة كيفية مقارنتها، أو حتى تغيير الألوان لمعرفة كيفية تأثير الاستقراء في التدرّج.

بالإضافة إلى تخصيص الاستقراء، تقدّم مساحات الألوان الأسطوانية (HSL وHWB وLCH وOKLCH) الكلمات الرئيسية shorter (التلقائية) أو longer لتحديد ما إذا كان يجب أن يسلك خط التدرّج المسار الطويل حول عجلة الألوان أو المسار القصير بين اللونَين.

.my-element {
  background: linear-gradient(in oklch longer hue, deeppink, yellow);
}

الموارد

التحقّق من فهمك

اختبِر معلوماتك حول التدرجات اللونية

ما هو الحد الأدنى لعدد الألوان المطلوب لإنشاء تدرج؟

1
يُرجى إعادة المحاولة.
2
يمكن أن يكونا من نفس اللون ويبدوان صلبين، ولكن يجب استخدام لونَين على الأقل.
3
يُرجى إعادة المحاولة.
4
يُرجى إعادة المحاولة.

هل يمكن أن تتضمّن العناصر تدرّجات متعددة كخلفية؟

True
تسمح السمة background-image بالعديد من التدرجات، ما عليك سوى فصلها بفاصلة.
خطأ
نعم، يمكنهم ذلك.