العناصر الزائفة Pseudo-elements والفئات الزائفة Pseudo-classes في CSS

ما هي Pseudo-classes و Pseudo-elements في CSS وكيف تستخدم مع الأمثلة عليها

العناصر الزائفة Pseudo-elements والفئات الزائفة Pseudo-classes في CSS

في CSS ماذا نعني بالعناصر الزائفة Pseudo-elements والفئات الزائفة Pseudo-classes… ؟! ماهو الفرق بين Pseudo-elements و Pseudo-classes في CSS..؟؟ وكيف تؤثر Pseudo-elements و Pseudo-classes على عناصر صفحة الويب …؟!! وكيف يتم استخدام Pseudo-elements و Pseudo-classes في صفحات الويب..؟؟

العناصر الزائفة Pseudo-elements والفئات الزائفة Pseudo-classes في CSS

من الأدوات التي توفرها الـ CSS لتنسيق تصميم صفحات الويب مجموعة العناصر الزائفة Pseudo-elements والفئات الزائفة Pseudo-classes ، في هذا المقال، سنكشف Pseudo-classes و Pseudo-elements في CSS، وسنستعرض أمثلة توضيحية ونقدم نصائح وإرشادات للاستفادة القصوى من هاتين الأداتين القويتين في عملية تنسيق صفحات الويب.لنبدأ….

في هذا المقال نتعرف على :



ماهي Pseudo-classes و Pseudo-elements؟

تعد لغة CSS (Cascading Style Sheets) أحد أهم أدوات تصميم وتنسيق صفحات الويب. توفر CSS مجموعة واسعة من الخصائص والمحددات التي تمكن المطورين من تحديد مظهر وتنسيق العناصر الفردية والمكونات المختلفة في صفحة الويب. ومن بين المحددات المتوفرة في CSS (المزيد عن المحددات في مقال CSS Selectors ) ، تبرز Pseudo-classes و Pseudo-elements كأدوات قوية لتحديد وتنسيق أجزاء محددة داخل العناصر.

العناصر الزائفة Pseudo-elements، هي محددات تسمح للمطورين بتنسيق أجزاء محددة داخل العناصر، بدلاً من تنسيق العنصر بأكمله. على سبيل المثال، يُمكن استخدام ::before Pseudo-element لإضافة محتوى إضافي قبل عنصر ما، مثل رمز أيقونة أو خط سفلي، وذلك بدون الحاجة إلى تعديل HTML الأساسي للصفحة.

أما بالنسبة للفئات الزائفة أو Pseudo-classes، هي Classes تسمح للمطورين بتحديد العناصر استنادًا إلى حالة معينة أو حالة تتغير بناءً على تفاعل المستخدم. على سبيل المثال، يُمكن استخدام :hover Pseudo-class لتحديد العنصر عندما يتم تحويل المؤشر فوقه، وبالتالي تمكين تغييرات التنسيق المذكورة في القواعد المرتبطة بهذه الفئة الزائفة

استخدام Pseudo-elements و Pseudo-classes في CSS يعزز قدرات التنسيق والتصميم البصري لصفحات الويب. يمكن للمطورين تحقيق تأثيرات مختلفة وتكوينات مرئية مبتكرة باستخدام هذه الأدوات. سواء كان ذلك لإظهار تأثيرات تفاعلية عند تحريك المؤشر فوق العناصر أو لإضافة تنسيقات إضافية لأجزاء محددة من العناصر، فإن استخدام Pseudo-classes و Pseudo-elements يساهم في إثراء تجربة المستخدم وتعزيز جاذبية التصميم العام للموقع.



العناصر الزائفة Pseudo-elements

في CSS ، يُعد العنصر الزائف (Pseudo Element) جزء من العنصر الفعلي يتم تحديده وتنسيقه بشكل مستقل باستخدام المحددات الزائفة. يتم استخدام العناصر الزائفة لإضافة تأثيرات وتنسيقات إضافية لعناصر HTML بدون تعديل الهيكل الأساسي للصفحة.

يتم تمثيل العناصر الزائفة Pseudo elements في CSS باستخدام قائمة محددات زائفة تبدأ بنقطتين رأستين مزدوجة (::). هناك مجموعة من العناصر الزائفة Pseudo-elements في CSS، تشمل التالي :

  1. ::before و يتيح لنا إضافة محتوى إضافي قبل عنصر محدد. يستخدم عادة لإضافة رموز أيقونات إلى العناصر.
  2. ::after يتيح لنا إضافة محتوى إضافي بعد عنصر محدد. يمكن استخدامه لإضافة فواصل أو رموز أيقونات بعد العناصر.
  3. فيما يلي مثال على طريقة استخدام كلاً من ::before و ::after

    ...........
    h1::before {content:"::... ";}
    h2::after { content:" ....::";}
    ...........

    الـ Output للمثال:


    العناصر الزائفة Pseudo-elements في CSS -::before and ::after

    المثال بالكامل على الرابط.


  4. ::first-letter ويستخدم لتنسيق الحرف الأول داخل عنصر نصي. يمكننا تغيير حجم الخط واللون والتسيقات للحرف الأول فقط. وتعمل فقط على عناصر block واحد يمكن تطبيق ::first-letter مع الخصائص:

  5. ::first-line: يستخدم لتنسيق السطر الأول داخل عنصر نصي. يمكنك تغيير الخط واللون والتباعد والتحكم في النص في السطر الأول. ويستخدم مع الخصائص التالية :
    • خصائص الخط Font properties.
    • واللون color properties.
    • الخلفية Background properties .
    • ومن خصائص النص Text properties التالي: ( vertical-align, ,line-height, text-transform,text-decoration, letter-spacing, word-spacing)

    وفي مايلي مثال على طريقة استخدام كلاً من ::first-letter و ::first-line

    ...........
    h1::first-letter {
      color: green;
      background-color: yellow;
      font-size: 40px;
    }
    p::first-line {
      color: red;
     word-spacing:10px;
    }
    ...........

    الـ Output للمثال:

    العناصر الزائفة Pseudo-elements في CSS -::first-line and ::first--letter

    المثال بالكامل على الرابط.


  6. ::marker ويستخدم لتنسيق عناصر القوائم <li>، و تظهر طريقة استخدامه في المثال التالي :
  7. ...........
    ::marker { color: blue;}
    ...........

    الـ Output للمثال:

    الفئات الزائفة Pseudo-classes-marker

    المثال بالكامل على الرابط.


  8. ::Selection بواسطته يتم تعيين التنسيق الذي يظهر عندما يقوم المستخدم بتحديد العنصر ويعمل مع الخصائص color , background, outline , cursor، وهنا مثال يوضح طريقة الاستخدام للـ ::selection :
  9. ...........
    ::selection {
     color:white;
     background-color: black;
    }
    ...........

    الـ Output للمثال:

    العناصر الزائفة Pseudo-elements في CSS -::selection

    المثال بالكامل على الرابط.


توفر العناصر الزائفة Pseudo elements في CSS المرونة والإمكانيات الإبداعية لتزيين العناصر وتحسين تصميم الصفحة دون تعديل الهيكل الأساسي للنصوص أو العناصر.



الفئات الزائفة Pseudo Classes في CSS

في CSS، تُعتبر الفئة الزائفة (Pseudo Class) محدد وهمي يتم استخدامه لتحديد حالة معينة أو حالة مؤقتة لعنصر HTML. تسمح الفئات الزائفة Pseudo-classes بتنسيق العناصر بناءً على حالة معينة، مثل وجود رابط في حالة التأشير عليه (hover) أو أن العنصر هو العنصر الأخير في القائمة (last-child).

تُمثل الفئات الزائفة Pseudo classes في CSS باستخدام قائمة محددات وهمية تبدأ بنقطتين رأسيتين (:). وفيما يلي بعض التصنيفات الشائعة للـ Pseudo classes في CSS مع الأمثلة عليها:



هي Pseudo Classes مصممة خصيصًا لتصميم عنصر الارتباط التشعبي <a> تمكننا هذه الـ Classes من تحديد أنماط مختلفة للروابط التي لم تتم زيارتها، والتي تمت زيارتها، والنشطة (التي تم النقر عليها). فيما يلي الأنواع والامثلة عليها:

  1. :link و يعمل مع العناصر التي تمثل الروابط ويستخدم في ضبط تنسيق الروابط التي لم تتم زيارتها.
  2. :visited و يعمل مع العناصر التي تمثل الروابط ويستخدم في ضبط تنسيق الروابط التي تمت زيارتها.
  3. :hover يُطبق على العنصر عندما يتم تحويل المؤشر فوقه. يُمكن استخدامه لتغيير التنسيق أو عرض معلومات إضافية عند تحويل المؤشر فوق عنصر محدد. ويجب أن يأتي a:hover بعد a:link و a:visited في تعريف CSS لكي يكون فعالاً.
  4. :active يُطبق على العنصر عند النقر عليه. يُمكن استخدامه لتنسيق العنصر أثناء النقر عليه، مثل تغيير اللون أو التباين لإظهار تأثير النقر. ويجب أن يأتي :hover في تعريف CSS لكي يكون فعالاً.

وفي المثال التالي طريقة استخدام كلاً من :link و :visited و :hover و :active مع الروابط :

...........
a:link {color: green;}
a:visited { color: gray ;}
a:hover {color: red;}
a:active { color: blue;}
...........

جرب /ي المثال على الرابط.


Pseudo Classes – Selectors Classes

تعتبر مجموعة Selectors Classes محددات لعناصر معينة من صفحة الويب، مما يتضح في طريقة عمل كلاً منها وهي :

:root يعتبر محدد للعنصر الجذر root في صفحة الويب، في HTML، العنصر الجذر هو دائمًا عنصر <html>،ويوضح المثال التالي طريقة استخدام :root

...........
:root{ background: yellow;}
...........

الـ Output للمثال:

Pseudo Classes – Selectors Classes -root

المثال بالكامل على الرابط.


:target يعمل كمحدد لعناصر الروابط (id) التي تشير الى عناصر في نفس صفحة الويب ويستخدم لضبط تنسيق العنصر الهدف (#)، ويوضح المثال التالي طريقة استخدام :target

...........
:target{ color: red;}
...........

. يمكنكم تجربة المثال على الرابط


:empty يحدد العناصر الخالية (عنصر بدون محتوى) في صفحة الويب. ويوضح المثال التالي طريقة استخدام :empty

...........
div:empty { width: 120px;  height: 30px;  background: yellow;}
...........

الـ Output للمثال:

Pseudo Classes – Selectors Classes -empty

 المثال بالكامل على الرابط.

:not(selector) يستخدم في تحديد عنصر معين مستثنى من نمط التنسيق. ويوضح المثال التالي طريقة استخدام :not(selector)

...........
p {color: blue;}
:not(p){ color: green;}
...........

الـ Output للمثال:

Pseudo Classes – Selectors Classes -not(selector)

المثال بالكامل على الرابط.


:lang(language) يعتبر محدد يضبط تنسيق العناصر التي لها السمة lang ، غالبًا ما تكون قيمة السمة lang عبارة عن رمز لغة مكون من حرفين، مثل ar للغة العربية و en للإنجليزية و ko الكورية. (المزيد من رموز اللغات هنـا ). ويوضح المثال التالي طريقة استخدام :lang()

...........
p:lang(mylang) { color: green;}
...........

الـ Output للمثال:

Pseudo Classes – Selectors Classes lang(language)

المثال بالكامل على الرابط.



الفئات الزائفة الهيكلية Structural Pseudo Classes

توفر CSS مجموعة من الفئات الزائفة الهيكلية (Structural Pseudo Classes) التي تسمح لك بتحديد العناصر بناءً على موضعها في بنية HTML. إنها تمكننا من استهداف عناصر محددة بناءً على ترتيبها أو نوعها داخل الحاوية الأصلية الخاصة بها. وتشمل هذه مجموعتين من الفئات وهي Child -Pseudo Classes

Child -Pseudo Classes

في Child -Pseudo Classes تصنف مجموعات العناصر في صفحة الويب بشكل هرمي أباء وأبناء حيث يبدأ التفرع من <body>، واهم Child -Pseudo Classes هي :

:only-child يعمل على العناصر الفرعية ويستخدم لضبط تنسيق في حالة وجود عنصر فرعي وحيد. ,وعند عدم تحديد عنصر والد يحدد جميع العناصر كأبناء للـ <body> وتتضح طريقة استخدام :only-child في المثال التالي:

...........
p:only-child{color: red;}
p b:only-child {color: green;}
p i:only-child {color: blue;}
...........

الـ Output للمثال:

Child -Pseudo Classes - only-child

المثال بالكامل على الرابط.


:first-child يعمل مع العناصر الفرعية ويُطبق على العنصر الفرعي الأول ضمن عنصر والد محدد. يُمكن استخدامها لتنسيق العناصر الأولى في القائمة أو أي مجموعة العناصر الفرعية.

:last-child يعمل نفس عمل :first-child لكن يُطبق على العنصر الأخير في القائمة أو أي مجموعة العناصر الفرعية.

في المثال على توضيح لطريقة استخدام كلاً من :first-child و :last-child

...........
p:first-child{color: red;}
p b:first-child {color: green;}
p i:last-child {color: blue;}
.myclass span:last-child{color:lightblue;}
...........

الـ Output للمثال:

Child -Pseudo Classes - first and last child

المثال بالكامل على الرابط.


:nth-child(n) يعمل على مجموعة عناصر من نوع واحد محدد أو على جميع مجموعات العناصر عند عدم تحديد نوع العنصر. ويُطبق على العنصر ذو الترتيب (n) الذي يكون رقم صحيح ويمكن أن يكون تعبير رياضي نتيجة تعطي ترتيب العنصر.

:nth-last-child(n) يعمل نفس عمل :nth-child(n) ولكن (n) هنا تمثل الترتيب العكسي للعناصر فمثلاً الترتيب 1 يشير الى العنصر الأخير في مجموعة العناصر و الترتيب 2 يشير الى العنصر قبل الأخير وهكذا.

في المثال توضيح لطريقة استخدام كلاً من :nth-child(n) و :nth-last-child(n)

...........
:nth-child(3){color:red;}/*Select the third item for any group of child elements*/
p:nth-child(2){color: blue;} /*Select the second item for any a group of child elements of type 

*/ p b:nth-last-child(3) {color: green;} p i:nth-child(1) {color: lightblue;} li:nth-last-child(2){color: lightgreen;} ...........


الـ Output للمثال:

Child -Pseudo Classes -nth-child and nth-last-child

المثال بالكامل على الرابط.



Of-Type Pseudo Classes

قد تبدو هذه المجموعة من الـ Classes مشابة لمجموعة Child-Pseudo Classes وهذا لان فى of-type Pseudo Classes يكون تصنيف عناصر صفحة الويب هرمي ولكن تختلف عن Child-Pseudo Classes أن التنصيف فى Of-Type Pseudo Classes يكون هرمي و بناء على نوع العناصر. وأهم أنواع Of-Type Pseudo Classes هي:

:only-of-type يُطبق على العنصر الوحيد ضمن نوع عنصر محدد. وفي حال عدم تحديد النوع يحدد كل عناصر الصفحة تماماً كما يعمل :only-child ، وكما يتضح في المثال التالي :

...........
:only-of-type{color:lightblue;}
p:only-of-type {color: red;}
p b:only-of-type {color: green;}
p i:only-of-type {color: blue;}
...........

الـ Output للمثال:

Of-Type Pseudo Classes -only-type

المثال بالكامل على الرابط.


:first-of-type يعمل مع عناصر من نوع واحد ويُطبق على العنصر الأول ضمن مجموعة العناصر. يُمكن استخدامها لتنسيق العناصر الأولى في القائمة أو مجموعة عناصر من نفس النوع.

:last-of-type يعمل نفس عمل :first-of-type لكن يُطبق على العنصر الأخير في لقائمة أو مجموعة عناصر من نفس النوع. .

وتتضح طريقة الإستخدام لكل من :first-of-type و :last-of-type في المثال التالي:

...........
p:first-of-type {color: red;}
p b:first-of-type {color: green;}
p i:last-of-type {color: blue;}
.myclass span:last-of-type{color:lightblue;
...........

الـ Output للمثال:

Of-Type Pseudo Classes -first and last of type

المثال بالكامل على الرابط .


:nth-of-type(n) و يعمل على مجموعة عناصر من نوع واحد محدد. ويُطبق على العنصر ذو الترتيب (n) الذي يكون رقم صحيح ويمكن أن يكون تعبير رياضي نتيجة تعطي ترتيب العنصر.

:nth-last-of-type(n) يعمل نفس عمل :nth-of-type(n) ولكن الترتيب (n) هنا تمثل الترتيب العكسي للعناصر فمثلاً الترتيب 1 يشير الى العنصر الأخير في مجموعة العناصر والتريب 2 يشير الى العنصر قبل الأخير وهكذا.

وتتضح طريقة الإستخدام لكل من :(n)nth-of-type و :nth-last-of-type(n) في المثال التالي:

...........
:nth-of-type(3) {color: red;} ;} /*Select the thrid item for any same type group of elements */
p:nth-of-type(2){color: blue;} /*Select the second items for every a group of elements of  type 

*/ p b:nth-last-of-type(3) {color: green;} p i:nth-of-type(1) {color: lightblue;} li:nth-last-of-type(2){color: lightgreen;} ...........


الـ Output للمثال:

Of-Type Pseudo Classes -nth-of-type and nth-last-of-type

.المثال بالكامل على الرابط




الفئات الزائفة ذات الصلة بالنموذج Form-related Pseudo Classes

في CSS فئات زائفة Pseudo Classes مصممة خصيصًا لعناصر النموذج، تسمح لك هذه الفئات بتصميم عناصر النموذج بناءً على حالة التحقق أو تفاعل المستخدم، وتتوفر في CSS العديد من Form-related Pseudo Classes منها التالي:


:focus يصنف أيضاً من فئات التفاعل الزائفة Interaction Pseudo Classes حيث يُطبق على العنصر الذي يكون في حالة التركيز. يعمل مع عناصر الإدخال من <input> يُمكن استخدامه لتنسيق العنصر عندما يتم تحديده بواسطة المستخدم مثل تغيير لون الخط أو إضافة تأثير بصري. حيث يطبق التنسيق عند وضع المؤشر على العنصر.ويوضح المثال التالي طريقة استخدام :focus :

...........
input:focus { background-color:lightblue;}
...........

جرب/ي المثال على الرابط .


:checked يعمل مع عناصر الإدخال المتعدد من <input> مثل الأنواع (Radio, buttons, checkbox ) أي عناصر الاختيار من متعدد ويضبط تنسيق العنصر الذي تم اختياره بواسطة المستخدم. كما يتضح في المثال التالي :

...........
input:checked { height: 20px; width: 20px;}
...........

الـ Output للمثال:

Form-related Pseudo Classes- checked

المثال بالكامل على الرابط .


:required يضبط تنسيق عناصر الإدخال التي لها سمة مطلوب Required ويعمل مع <input> و <textarea> .

:optional يضبط تنسيق عناصر الإدخال التي لم تحدد لها سمة مطلوب Required ويعمل مع <input> و <textarea>.

وتتضح طريقة الاستخدام لكل من :required و :optional في المثال التالي

...........
input:required { border: 2px solid red;}
input:optional { border: 2px solid green;}
...........

الـ Output للمثال:

Form-related Pseudo Classes-required and optional

المثال بالكامل على الرابط .


:valid يضبط تنسيق عناصر الإدخال ذات القيود فقط، مثل عناصر الإدخال ذات سمات الحد الأدنى والحد الأقصى من عدد القيم المدخلة، مثل حقول البريد الإلكتروني، أو حقول الأرقام ذات القيمة الرقمية، وما إلى ذلك. ويطبق التنسيق فقط في حال تم ادخال قيمة صحيحة متوافقة مع قيود العنصر .

:invalid يعمل مع بنفس الطريقة التي يعمل بها :valid ولكن ويطبق التنسيق فقط في حال تم ادخال قيمة خاطئة وغير متوافقة مع قيود العنصر .

وتتضح طريقة الاستخدام لكل من :valid و :invalid في المثال التالي :

...........
input:valid { border: 2px solid green;}
input:invalid { border: 2px solid red;}
...........

جرب /ي المثال على الرابط .


:disable يضبط تنسيق عناصر الإدخال التي لها سمة معطل disable .

:enable يضبط تنسيق عناصر الإدخال التي لم يتم تعيين لها سمة معطل disable .

وتتضح طريقة الاستخدام لكل من :disable و :enable في المثال التالي :

...........
input[type=text]:enabled { background: lightgreen ;}
input[type=text]:disabled { background: #f1f1f1;}
...........

الـ Output للمثال:

Form-related Pseudo Classes-disable and enable

المثال بالكامل على الرابط.


:read-only يضبط تنسيق عناصر الإدخال التي لها سمة للقراءة فقط readonly .

:read-write يضبط تنسيق عناصر الإدخال التي لم يتم تعيين لها أي من السمات معطل disable أو للقراءة فقط readonly .

وتتضح طريقة الاستخدام لكل من :read-only و :read-write في المثال التالي :

...........
input:read-only { background: #f1f1f1;}
input:read-write{ background: lightblue;}
...........

الـ Output للمثال:

Form-related Pseudo Classes read-only and read-write

المثال بالكامل على الرابط.


:in-range يضبط تنسيق عناصر الإدخال التي لها سمات تحديد النطاق الحد الأدنى (min) والحد الأقصى (max) ويطبق التنسيق في حال تم ادخال قيمة ضمن النطاق.

:out-of-range يعمل بنفس طريقة :in-range ولكن يطبق التنسيق في حال تم ادخال قيمة خارج النطاق المحدد.

وتتضح طريقة الاستخدام لكل من :in-range و :out-of-range في المثال التالي :

...........
input:in-range {border: 2px solid green;}
input:out-of-range {border: 2px solid red;}
...........

جرب /ي المثال على الرابط.


إن الفئات الزائفة Pseudo Classes في CSS تتيح طرقًا قوية لاستهداف العناصر وتصميمها بناءً على الظروف المختلفة وتفاعلات المستخدم. فهي توفر المرونة والتحكم في مظهر صفحات الويب وسلوكها، مما يسمح لك بإنشاء تجارب مستخدم جذابة وتفاعلية.



أهم مكتبات العمل مع Pseudo-classes و Pseudo-elements في CSS

هناك العديد من مكتبات CSS التي توفر دعمًا وتسهل استخدام Pseudo-classes و Pseudo-elements. نستعرض فيما يلي بعض أهم هذه المكتبات:

  • Bootstrap: مكتبة Bootstrap هي واحدة من أشهر مكتبات CSS في عالم تطوير الويب. توفر Bootstrap مجموعة واسعة من الفئات الزائفة المدمجة والتي يمكن استخدامها بسهولة لتحقيق تأثيرات مختلفة على العناصر والأجزاء.
  • Foundation: تعتبر مكتبة Foundation واحدة من المكتبات الشهيرة التي توفر أدوات تصميم متقدمة وتنسيقات مدمجة للاستفادة من Pseudo-classes و Pseudo-elements. تتيح Foundation إمكانية تخصيص العناصر بسهولة باستخدام مجموعة متنوعة من الفئات الزائفة.
  • jQuery: على الرغم من أن jQuery ليست بالضرورة مكتبة CSS، إلا أنها توفر واجهة برمجة تطبيقات (API) قوية للتعامل مع العناصر والفئات الزائفة في CSS. يمكن استخدام jQuery لإضافة وإزالة الفئات الزائفة والتحكم في التنسيق والتصميم بسهولة.
  • CSS3-Magic: تعتبر CSS3-Magic مكتبة متخصصة في توفير تأثيرات متقدمة باستخدام CSS3، بما في ذلك Pseudo-classes و Pseudo-elements. توفر هذه المكتبة مجموعة متنوعة من القوالب والتأثيرات الجاهزة التي يمكن دمجها وتخصيصها بسهولة في المشاريع.
  • Animate.css: تعتبر Animate.css مكتبة شائعة توفر تأثيرات الرسوم المتحركة باستخدام CSS. تتضمن هذه المكتبة تأثيرات مختلفة للاستفادة من Pseudo-classes و Pseudo-elements، مما يمنحك إمكانية إضافة حركة ودينامية للعناصر في صفحتك بسرعة وسهولة.

هذه مجرد بعض الأمثلة على المكتبات الشهيرة التي تدعم Pseudo-classes و Pseudo-elements في CSS. هناك المزيد من المكتبات المتاحة حسب احتياجات المشروع والتفضيلات الشخصية. يجب علينا استكشاف هذه المكتبات واختيار الأداة التي تناسب متطلبات التصميم الخاصة بنا.



الطرق المثلى لاستخدام Pseudo-classes و Pseudo-elements في CSS

عند استخدام Pseudo-classes و Pseudo-elements في CSS، هناك بعض الطرق المثلى التي يمكن اتباعها للحصول على أفضل أداء وتجربة للمستخدم. فيما يلي بعض النصائح:

  • الترتيب الصحيح: يجب وضع Pseudo-classes بعد اختيار العنصر الأساسي. على سبيل المثال، إذا كنا تريد تطبيق نمط على الروابط التي تكون في حالة فأننا بحاجة إلى كتابة العنصر المحدد للروابط ثم تطبيق الـ "Pseudo-class" المناسبة.
  • الاستخدام الحكيم: استخدم Pseudo-classes و Pseudo-elements عندما يكون لدينا حاجة فعلية لتغيير التنسيق أو تطبيق تأثير معين على العناصر. علينا تجنب استخدامها بشكل مفرط أو غير ضروري، حيث يمكن أن يؤدي ذلك إلى تعقيد الأكواد وزيادة وقت التحميل.
  • الاستفادة من القواعد الشائعة: تعتبر Pseudo-classes مثل :hover و :active و :focus من أكثر القواعد استخدامًا وتقدم تجربة تفاعلية للمستخدم. استخدم هذه القواعد بحكمة لتحسين التجربة وإضفاء لمسة احترافية على التصميم.
  • تنسيقات النص الإضافية: استخدم Pseudo-elements مثل ::before و ::after لإضافة محتوى إضافي إلى العناصر. يمكن استخدام هذه التنسيقات لإضافة رموز أو رموز تعبيرية أو تنسيقات مخصصة إلى العناصر، مما يساعد في تعزيز التواصل وتحسين تجربة المستخدم.
  • التنظيم الجيد للأكواد: يجب تنظيم الأكواد المتعلقة بـ Pseudo-classes و Pseudo-elements بشكل جيد للحفاظ على الوضوح وسهولة الصيانة. استخدم التعليقات لتسمية وتوضيح استخدامات الفئات والعناصر الزائفة لتسهيل فهم الأكواد.
  • التجربة والاختبار: قبل نشر الموقع أو التطبيق، يجب اختبار Pseudo-classes و Pseudo-elements على مختلف المتصفحات والأجهزة للتأكد من أنها تعمل بشكل صحيح وتقدم التجربة المرجوة.

باستخدام هذه الطرق المثلى، يمكننا الاستفادة القصوى من Pseudo-classes و Pseudo-elements في CSS وتحقيق تصاميم مبتكرة ومتقدمة. علينا أن نتذكر دائمًا أن التطبيق Pseudo-classes و Pseudo-elements قد يختلف بين مشاريع التصميم المختلفة، لذا يجب أخذ الاحتياجات الفردية لكل مشروع في الاعتبار.



خاتمة:

باستخدام المعرفة المكتسبة حول Pseudo-classes و Pseudo-elements وتطبيقها بشكل إبداعي، يمكننا تحسين تجربة المستخدم وإضفاء لمسة فريدة ومبتكرة على تصميماتنا. كما علينا أن تذكر دائمًا أن التصميم ليس فقط مسألة للعين، بل أيضًا لتجربة المستخدم وراحته وفهمه للمحتوى. أخيراً نأمل أن يكون هذا المقال قدم لك رؤية واضحة حول Pseudo-classes و Pseudo-elements في CSS وكيفية استخدامها بفعالية في تصميم صفحات الويب.


إرسال تعليق

فضلاً اترك تعليق
موافقة ملفات تعريف الارتباط
لتحسين تجربتك… يستخدم موقعنا ملفات تعريف الارتباط (Cookies)
Oops!
It seems there is something wrong with your internet connection. Please connect to the internet and start browsing again.
AdBlock Detected!
We have detected that you are using adblocking plugin in your browser.
The revenue we earn by the advertisements is used to manage this website, we request you to whitelist our website in your adblocking plugin.
Site is Blocked
Sorry! This site is not available in your country.