css 101 المحددات (Selectors) في CSS


محمد فوّاز عرابي

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

css-selectors.png

فهرس السلسلة:

ما هي المحددات؟

لـCSS مجموعة من المصطلحات الخاصة الّتي تصف اللّغة. كنّا قد أنشأنا سطرًا في ورقة الأنماط محتواه:

strong { color: red; }

وفي مصطلحات CSS نقول عن هذا السّطر أنّه قاعدة (rule). تبدأ هذه القاعدة بالكلمة strong والّتي نُسمّيها المحدِّد (selector)، لأنّه يحدّد العناصر في DOM الّتي تُطبّق عليها القاعدة المعنيّة.

تفاصيل أكثر

  • نُسمّي الجزء ضمن القوسين من القاعدة التّصريح (declaration).
  • الكلمة color تُسمّى خاصّة (property)، وقيمتها (value) هي red.
  • تفصل الفاصلة اللاتينية المنقوطة ; بين أزواجٍ من القيم والخواص ضمن التّصريح ذاته.
  • سنطلق على المُحدّد strong في هذه السلسلة وصف محدّد لوسم (tag selector)، إلّا أنّه في مصطلحات CSS يُسمّى محدّد لنوع (type selector).

يُفصِّل هذا الدرس من السلسلة المحدّدات التي يمكن استخدامها في قواعد CSS، فبالإضافة إلى أسماء الوسوم، يمكن استخدام قيم الخواص (attributes) في المُحدّدات، وهذا ما يسمح لقواعد CSS بتحديد أكثر انتقائيّة للعناصر.

للخاصّتين class وid وضع خاصّ في CSS.

محددات الأصناف (Class selectors)

استخدم الخاصّة class في HTML لإسناد صنف إلى العنصر، بإمكانك اختيار أي اسم للصنف، ويمكن للصّنف الواحد أن يُسند إلى عدّة عناصر في الصّفحة.

لاستخدام محدّد الصنف في CSS اكتب اسم الصّنف مسبوقًا بنقطة (.).

محددات المعرفات (ID selectors)

استخدم الخاصّة id في عنصر لإسناد مُعرّف إلى هذا العنصر، بإمكانك اختيار أي اسم للمُعرّف، ولكن ينبغي أن لا يكون لعنصرين في الصّفحة المُعرّف ذاته.

لاستخدام مُحدّد المعرّف في CSS، اكتب اسم المُعرّف مسبوقًا برمز #.

مثال:

لوسم HTML التالي خاصّتا الصّنف والمعرّف معًا:

<p class="key" id="principal">

قيمة الخاصّة id، وهي principal يجب أن تكون فريدة لا تتكرّر في كامل المستند، ولكن يمكن استخدام الصّنف key لأي عدد من العناصر.

القاعدة التالية في CSS تجعل كل العناصر في المستند خضراء اللون، حتى وإن تكن جميعها عناصر <p>:

.key {
  color: green;
}

القاعدة التالية تجعل العنصر الوحيد ذا المعرّف principal عريض الخطّ:

#principal {
  font-weight: bolder;
}

محددات الخواص (Attribute Selectors)

لا تقتصر CSS على الخاصتين class وid، بل يمكنك تحديد خواصّ أخرى باستخدام الأقواس المربّعة []. ضع اسم الخاصة ضمن القوسين وأتبعه بعامل ثم قيمة (غير إلزاميّين). يمكن أيضًا جعل المطابقة غير حسّاسة لحالة الحروف اللّاتينية بإضافة "i" بعد القيمة، ولكن هذه الميزة غير مدعومة في معظم المتصفّحات. أمثلة:

  • ‏‎[disabled]: تحدّد كل العناصر التي تملك الخاصّة "disabled".
  • ‏‎[type='button']‎: تحدد كل العناصر من النوع "button".
  • ‏‎[class~=key]‎: تحدّد العناص ذات الصّنف "key" بالضّبط وليس أي كلمة تحوي ضمنها "key" مثل "keyed" أو "monkey". تطابق من حيث الوظيفة المُحدّد .key.
  • ‏‎:[lang|=es]‎ تحدّد العناصر المحدّدة على أنّها باللّغة الإسبانية. هذا يتضمن العناصر "es" و"es-MX" ولكن ليس "eu-ES".
  • ‏‎[title*="example" i]‎ يحدّد العناصر التي يحوي عنوانها "example"، متجاهلًا حالة الحروف اللاتينيّة، قد لا يطابق هذا العنصر أي شيء في المتصفّحات الّتى لا تدعم الإشارة "i".
  • ‏‎a[href^="https://"]‎ يحدّد الرّوابط الآمنة.
  • ‏‎img[src$=".png"]‎ يحدّد الصور بصيغة PNG بطريقة غير مباشرة، إلّا أنه لا يحدد الصور بصيغة PNG إن كانت روابطها لا تنتهي بالحروف ".png".

محددات الأصناف الزائفة (pseudo-classes)

تعني كلمة "الصّنف الزائف" في CSS حالة خاصّة للعناصر التي يُراد تحديدها، فمثلًا إضافة ‎:hover‎ إلى المحدّد يؤدّي إلى تطبيق القاعدة عندما يُمرّر المستخدم مؤشّر الفأرة فوق العنصر الذي يستهدفه المُحدّد.

تسمح الأصناف الزائفة (والعناصر الزائفة) بتطبيق تنسيق على عنصر عندما يخضع لعوامل خارجيّة كتاريخ التّصفّح (‎:visited‎ مثلًا)، أو حالة محتواه (مثل ‎:checked)، أو موضع الفأرة (مثل ‎:hover‎)، يمكنك مراجعة القائمة الكاملة للمحدّدات على صفحة توصيف مُحدّدات CSS3.

الصيغة

selector:pseudo-class {
  property: value;
}

قائمة بالأصناف الزائفة

  • :link
    :visited
    :active
    :hover
    :focus
    :first-child
    :last-child
    :nth-child
    :nth-last-child
    :nth-of-type
    :first-of-type
    :last-of-type
    :empty
    :target
    :checked
    :enabled
    :disabled

عمق التحديد (Specificity)

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

تفاصيل أكثر

يمكنك أيضًا جمع المُحدّدات، مُنشِئًا مُحدّدًا أكثر عمقًا، فمثلًا يحدّد key. كل العناصر من الصّنف key، والمُحدّد p.key يحدّد فقط العناصر <p> ذات الصّنف key.

إن تساوت المُحدّدات بدرجة العمق، كانت الأولوية للقاعدة الّتي ترد آخرًا في ورقة الأنماط.

التحديد تبعا للعلاقات بين العناصر

يمكن في CSS تحديد العناصر بناءً على علاقتها بعناصر أخرى، ويمكن بذلك إنشاء مُحدِّدات أكثر عمقًا.

المحددات الشائع استخدامها بناء على علاقة العناصر

المُحدّد يُحدِّد
A E أي عنصر E يكون من سلالة A (أي ابنه أو ابن ابنه...)
A > E أي عنصر E يكون ابنًا مباشرًا للعنصر A
E:first-child أي عنصر E يكون أوّل ابن لأبيه
B + E أي عنصر E يكون أول أخٍ لعنصر B (أي الابن التالي لنفس الأب)

يمكن أيضًا جمع أيّ من هذه المُحدّدات للتّعبير عن علاقات أكثر تعقيدًا.

يمكن استخدام الرّمز * للإشارة إلى "أي عنصر".

مثال

لجدول HTML التالي خاصّة id، ولكن ليس لسطوره وخلاياه أيّة مُعرّفات:

<table id="data-table-1">
...
<tr>
  <td>Prefix</td>
  <td>0001</td>
  <td>default</td>
</tr>
...

القواعد التالية تجعل الخليّة الأولى في كل سطر عريضة الخطّ، والثّانية ذات خطّ ثابت العرض، ولا تنطبق هذه القواعد إلا على الجدول السّابق المستند:

#data-table-1 td:first-child {text-decoration: underline;}
#data-table-1 td:first-child + td {text-decoration: line-through;}

هذه هي النّتيجة:

table.png

تفاصيل أكثر

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

لمزيد من الأمثلة عن الجداول، راجع صفحة الجداول في مرجع CSS.

تدريب: استخدام محددات الأصناف والمعرفات

  1. حرّر ملفّ HTML الّذي تتدرّب عليه، كرّر الفقرة بنسخها ولصقها.
  2. أضف الخاصّتين id وclass إلى النّسخة الأولى من الفقرة، وأضف id إلى الثّانية كما في المثال أدناه، أو يمكنك نسخ كامل المثال:
    <!doctype html>
    <html>
     <head>
     <meta charset="UTF-8">
     <title>Sample document</title>
     <link rel="stylesheet" href="style1.css">
     </head>
     <body>
       <p id="first">
         <strong class="carrot">C</strong>ascading
         <strong class="spinach">S</strong>tyle
         <strong class="spinach">S</strong>heets
       </p>
       <p id="second">
         <strong>C</strong>ascading
         <strong>S</strong>tyle
         <strong>S</strong>heets
       </p>
     </body>
    </html>
  3. عدّل CSS مُستبدلًا كامل محتوى الملفّ:
    strong { color: red; }
    .carrot { color: orange; }
    .spinach { color: green; }
    #first { font-style: italic; }
  4. احفظ الملفّات وحدّث المتصفّح لترى النّتيجة:

    selectors.png

    بإمكانك تغير ترتيب الأسطر في CSS للتأكد من أن ترتيبها لا يؤثّر على النّتيجة، لأن مُحدّدات الأصناف carrot. و spinach. مُقدَّمَة على مُحدّد الوسم strong، ومُحدّد المُعرّف first# مُقدّم عليها جميعًا.

تمرين

  1. بدون تعديل ملف HTML، أضف قاعدة وحيدة إلى CSS تبقي كل الحروف الأولى بنفس لونها الحالي، ولكن تجعل الحروف الأخرى في الفقرة الثّانية زرقاء:

    c1.png

  2. عدّل القاعدة الّتي أضفتها للتوّ بحيث تجعل الفقرة الأولى زرقاء أيضًا (بدون تعديل أي شيء آخر):

    c2.png

 

جعل الفقرة الثانية زرقاء اللون

أضف قاعدة تستهدف #second وتصريحًا color: blue; كما يلي:


 
#second { color: blue; }

يمكن أيضًا استخدام مُحدّد أكثر عُمقًا مثل p#second.

جعل الفقرتين زرقاوين

غيّر مُحدّد القاعدة الجديدة ليصبح مُحدّد وسم <p>:

p { color: blue; }

 

قواعد الألوان الأخرى لها مُحدّدات أكثر عمقًا، لذا فهي تطغى على لون الفقرات الأزرق.

مثال عملي: استخدام محددات الأصناف الزائفة

  1. أنشئ ملف HTML بالمحتوى التالي:
    <!doctype html>
    <html>
     <head>
     <meta charset="UTF-8">
     <title>Sample document</title>
     <link rel="stylesheet" href="style1.css">
     </head>
     <body>
       <p>Go to our <a class="homepage" href="http://www.example.com/" title="Home page">Home page</a>.</p>
     </body>
    </html>
  2. عدّل ملف CSS مستبدلًا كلّ محتواه:

     a.homepage:link, a.homepage:visited {
       padding: 1px 10px 1px 10px;
       color: #fff;
       background: #555;
       border-radius: 3px;
       border: 1px outset rgba(50,50,50,.5);
       font-family: georgia, serif;
       font-size: 14px;
       font-style: italic;
       text-decoration: none;
     }
    
     a.homepage:hover, a.homepage:focus, a.homepage:active {
       background-color: #666;
     }
  3. احفظ الملفّين وحدّث المتصفّح لمشاهدة النّتيجة (ضع مؤشر الفأرة فوق الرّابط لمشاهدة التأثير):

Go to our Home page

تدريب: استخدام المحددات بناء على العلاقات بين العناصر والأصناف الزائفة

بالإمكان الوصول إلى طرق معقدة لاستهداف العناصر بناء على العلاقات بين عناصرها والأصناف الزائفة، تشيع هذه التقنيات مثلًا بهدف إنشاء قوائم مُنسدلة باستخدام CSS فقط دون JavaScript. أساس هذه التقنية يعتمد على قواعد مشابهة لهذه:

div.menu-bar ul ul {
  display: none;
}

div.menu-bar li:hover > ul {
  display: block;
}

بحيث تطبّق على بنية HTML مثل هذه:

<div class="menu-bar">
  <ul>
    <li>
      <a href="example.html">Menu</a>
      <ul>
        <li>
          <a href="example.html">Link</a>
        </li>
        <li>
          <a class="menu-nav" href="example.html">Submenu</a>
          <ul>
            <li>
              <a class="menu-nav" href="example.html">Submenu</a>
              <ul>
                <li><a href="example.html">Link</a></li>
                <li><a href="example.html">Link</a></li>
                <li><a href="example.html">Link</a></li>
                <li><a href="example.html">Link</a></li>
              </ul>
            </li>
            <li><a href="example.html">Link</a></li>
          </ul>
        </li>
      </ul>
    </li>
  </ul>
</div>

اطّلع على مثالنا الكامل كمساعدة.

ما التالي؟

بدأت ورقة الأنماط تصبح معقّدة ومتشابكة، سنناقش كيف نُبسّطها ونجعلها سهلة القراءة في الدّرس القادم: كيفية كتابة تعليمات CSS يسهل قراءتها.

ترجمة -وبتصرّف- للمقال Selectors من سلسلة Getting started with CSS على شبكة مطوّري Mozilla.





تفاعل الأعضاء


لا توجد أيّة تعليقات بعد



يجب أن تكون عضوًا لدينا لتتمكّن من التعليق

انشاء حساب جديد

يستغرق التسجيل بضع ثوان فقط


سجّل حسابًا جديدًا

تسجيل الدخول

تملك حسابا مسجّلا بالفعل؟


سجّل دخولك الآن