CSS Selectors

CSS Selectors

When we gave our html element more functionality so we use selector. In the sense of the selector we target html element like that p, div, h1 etc. or we use class, Id, chained, pseudo class, pseudo element selector etc.

Selectors are many type but here we read only some of those whose are important or we will use more of them for our purpose.

CSS Selector Category:

1st:- Simple Selectors:

2nd:- Combinator Selectors:

3rd:- Pseudo Selectors:

Universal Selector:

  • If we want select are html element in our page so we use Universal Selector(*).

Syntax:
*{ style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>CSS Universal Selectors</title>

    <style>
      /* style using normal css*/
      /* I am giving here border in  all html elements using other css selector */

      /* p,
      div,
      body,
      html {
        margin: 25px;
        border: 4px solid #ff592f;
      } */

      /* So insted of using p,div,body,html we want use only Astrick(*) css selector. */
      * {
        margin: 25px;
        border: 4px solid #ff592f;
      }
      /*Note:- You can see difference using comment or uncomment one of them selector */
    </style>
  </head>
  <body>
    <!-- Universal Selector -->

    <div>
      <p>Lorem ipsum dolor sit, amet consectetur omnis!</p>
      <p>Lorem ipsum dolor sit, amet consectetur omnis!</p>
      <p>Lorem ipsum dolor sit, amet consectetur omnis!</p>
      <p>Lorem ipsum dolor sit, amet consectetur omnis!</p>
    </div>
  </body>
</html>

Screenshot-universal-selector.jpg

Individual Selector:

Individual selector are select all same element available in page.

Syntax:

element name(p/h1/h2/img/a) { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Individual Selector</title>
    <style>
      /* Indvidual Selector */
      p {
        border: 4px solid #008000;
        color: blue;
        font-size: 500;
      }

     h1 {
        color: rgb(154, 72, 172);
      }

      h2 {
        color: red;
      }

      h3 {
        color: rgb(76, 251, 96);
      }
    </style>
  </head>
  <body>
    <p>Lorem ipsum dolor sit, amet consectetur adipisicing elit.</p>

    <div>
      <h1>Lorem ipsum dolor sit.</h1>
      <p>Lorem ipsum dolor sit amet.</p>
    </div>

    <h3>Lorem, ipsum dolor.</h3>

    <p>Lorem ipsum dolor sit amet.</p>

    <h2>Lorem, ipsum dolor.</h2>

    <ul>
      <li>
        <p>Lorem ipsum dolor sit amet consectetur.</p>
      </li>
    </ul>
  </body>
</html>

Screenshot-indvidual-selector.jpg

Class & Id Selectors :

When we use Individual selector they select all element in the page, So when we target a special element not all element available in page, we use id or class or both selector.

Class Selector:-

When we want targeted a spacefic element then we injected inside tag our class name and provide some additional functionality. When we write class selector name in css we use dot(.) before write class name.

Syntax: # class name { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Class & Id Selectors</title>

    <style>
      /* universal selector */
      * {
        margin: 25px;
      }

      /* Class Selector */
      .bgc_color {
        background-color: aqua;
        padding: 10px 5px;
      }

      .text_color {
        color: red;
        font-weight: bold;
      }

      /* Id Selector */

      /* #font_size {
        font-size: 50px;
      }

      #text_color {
        color: brown;
        font-weight: 900;
        font-size: 20px;
      } */
    </style>
  </head>
  <body>
    <div>
      <ul>
        <li class="bgc_color">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li>
        <li class="bgc_color text_color">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li>
        <li>Lorem ipsum dolor sit amet consectetur adipisicing elit.</li>
        <!-- <li id="font_size">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li>
        <li id="text_color">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li> -->
      </ul>
    </div>
  </body>
</html>

Screenshot-class-selector.jpg

Id Selector:

In html page we use only one id name(same name can not be use) in id selector. When we write id selector name in css we use hashtag(#) before write id name.

Syntax: # id name { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Class & Id Selectors</title>

    <style>
      /* universal selector */
      * {
        margin: 25px;
      }

      /* Class Selector */
      /* .bgc_color {
        background-color: aqua;
        padding: 10px 5px;
      }

      .text_color {
        color: red;
        font-weight: bold;
      } */

      /* Id Selector */

      #font_size {
        font-size: 50px;
      }

      #text_color {
        color: brown;
        font-weight: 900;
        font-size: 20px;
      }
    </style>
  </head>
  <body>
    <div>
      <ul>
        <!-- <li class="bgc_color">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li>
        <li class="bgc_color text_color">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li> -->

        <li>Lorem ipsum dolor sit amet consectetur adipisicing elit.</li>
        <li id="font_size">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li>
        <li id="text_color">
          Lorem ipsum dolor sit amet consectetur adipisicing elit.
        </li>
      </ul>
    </div>
  </body>
</html>

Id-selector.jpg

Chained Selector:

Chained selector giving more Specificity, so this is make the hire probability applying the CSS rule those have high specificity , if another selector have lower Specificity, so this selector will not be apply css rule .

Syntax:

.classname.classname#idname { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Chained Selector</title>

    <style>
      div {
        margin: 50px;
      }

      p.chained.selector#selectors {
        font-weight: 900;
        font-size: 20px;
        color: red;
      }
    </style>
  </head>
  <body>
    <div>
      <p class="chained selector" id="selectors">
        Lorem ipsum dolor sit amet consectetur adipisicing elit. Veritatis!
      </p>
      <p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Veritatis!</p>
      <p class="chained selector">
        Lorem ipsum dolor sit amet consectetur adipisicing elit. Veritatis!
      </p>
    </div>
  </body>
</html>

Screenshot-chained-1-selector.jpg

Combined Selector:

Combined selector means basically we use using comma , and grouping all selector with together. When we gave same css property then we use combined selector.

Syntax:

p, h1, h2, img, div, .warning, #alert { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Combined Selector</title>

    <style>
      /* combined selector */
      h2,
      .text_color,
      #font_color,
      p {
        margin: 25px;
        padding: 25px;
        color: red;
        background-color: rgb(142, 239, 236);
      }
    </style>
  </head>
  <body>
    <div>
      <h2>Combined Selector</h2>
      <p class="text_color">Lorem ipsum dolor sit amet consectetur.</p>
    </div>

    <p id="font_color">Lorem ipsum dolor sit.</p>

    <ul>
      <li>
        <p>
          Lorem ipsum dolor, sit amet consectetur adipisicing elit. Aliquam!
        </p>
      </li>
    </ul>
  </body>
</html>

chained-selector.jpg

Direct Child Selector:

Direct child selector means parent direct child, If my div container is parent and inside we write paragraph(p) and then write other siblings ul and inside ul write li and inside li we write paragraph(p). So here after div we write paragraph so this will be our direct child not inside's li's paragraph.

Syntax:

parent element name > direct child name { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Direct Child Selector</title>

    <style>
      body {
        background-color: #9d9a9a;
      }

      /* Direct Child Selector */

      div > p {
        text-align: center;
        color: #fff;
        font-size: 40px;
        font-weight: 800;
      }
    </style>
  </head>
  <body>
    <div>
      <p>Lorem ipsum dolor sit amet consectetur adipisicing elit.</p>

      <ul>
        <li>
          <p>
            Lorem ipsum dolor sit amet consectetur adipisicing elit. Molestiae,
            dolorum reprehenderit fuga accusantium esse dolor et alias porro
            maxime officia, illum ab? Quo blanditiis quibusdam dolorum sit,
            architecto veritatis temporibus.
          </p>
        </li>
      </ul>

      <p>Lorem ipsum dolor sit amet, consectetur adipisicing.</p>
    </div>
  </body>
</html>

direct-child.jpg

Adjacent Sibling Selector:

Adjacent sibling selector(+) are separates two selectors and select to the only immediately next element, and must both are children of the same parent.

Syntax:

former_element + target_element { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Sibling Selector</title>

    <style>
      body {
        margin: 40px;
      }

      /* Adjacent Sibling Selector */

      h1 + P {
        text-align: center;
        padding: 20px;
        font-size: 40px;
        background-color: aquamarine;
      }

      /* General Sibling Selector */
      /* h2 ~ p {
        text-decoration: none;
        padding: 10px;
        font-size: 30px;
        background-color: red;
      } */
    </style>
  </head>
  <body>
    <div>
      <h1>Adjacent Sibling Selector</h1>

      <p>Lorem ipsum consectetur adipisicing.</p>

      <p>Lorem ipsum dolor sit amet consectetur adipisicing.</p>

      <p>Lorem ipsum dolor sit amet consectetur adipisicing.</p>

      <!-- <h2>General Sibling Selector</h2>
      <p>Lorem ipsum dolor sit amet consectetur.</p>
      <p>Lorem ipsum dolor sit amet consectetur.</p>
      <p>Lorem ipsum dolor sit amet consectetur.</p>

      <ul>
        <li>
          <p>Lorem ipsum dolor sit amet.</p>
          <p>Lorem ipsum dolor sit amet.</p>
          <p>Lorem ipsum dolor sit amet.</p>
        </li>
      </ul>

      <p>Lorem ipsum dolor sit amet consectetur.</p>
      <p>Lorem ipsum dolor sit amet consectetur.</p> -->
    </div>
  </body>
</html>

adjacent-sibling-selector-1.jpg

General Sibling Selector:

General sibling selector(~) are separates two selectors, and after former element target to next similar elements are applies on all same css property, when we using general sibling selector, but here is catch the all children element be must only one parent container and not necessarily all element are immediately former element.

Syntax:

former_element ~ target_element { style properties }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Sibling Selector</title>

    <style>
      body {
        margin: 40px;
      }

      /* Adjacent Sibling Selector */

      /* h1 + P {
        text-align: center;
        padding: 20px;
        font-size: 40px;
        background-color: aquamarine;
      } */

      /* General Sibling Selector */
      h2 ~ p {
        text-decoration: none;
        padding: 10px;
        font-size: 30px;
        background-color: rgb(0, 225, 255);
      }
    </style>
  </head>
  <body>
    <div>
      <!-- <h1>Adjacent Sibling Selector</h1>

      <p>Lorem ipsum consectetur adipisicing.</p>

      <p>Lorem ipsum dolor sit amet consectetur adipisicing.</p>

      <p>Lorem ipsum dolor sit amet consectetur adipisicing.</p> -->

      <h2>General Sibling Selector</h2>
      <p>Lorem ipsum dolor sit amet consectetur.</p>
      <p>Lorem ipsum dolor sit amet consectetur.</p>
      <p>Lorem ipsum consecteturdolor sit amet consectetur.</p>

      <ul>
        <li>
          <p>consectetur. Lorem ipsum dolor sit amet.</p>
          <p>Lorem ipsum consectetur. dolor sit amet.</p>
          <p>Lorem ipsum dolor sit amet .</p>
        </li>
      </ul>

      <p>Lorem ipsum dolor sit amet consectetur.</p>
      <p>Lorem ipsum dolor sit amet consectetur.</p>
    </div>
  </body>
</html>

general-sibling-seclector.jpg

Pseudo Class Selector:

we use this selector giving additional specific property without using class and id selector. Pseudo class have many selector but here we use for example only :hover state before hover use colon(:) and then write pseudo class name.

Syantax:

button:hover { box-shadow: inset -10px -20px 4px 2px #f0e8f8; background-color: #fff; color: #8a2be2; }

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Pseudo Class Selector</title>

    <style>
      div {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1000px;
        height: 700px;
        margin: 0 auto;
        background-color: rgb(185, 186, 186);
      }
      button {
        border: none;
        border-radius: 40px;
        outline: none;
        padding: 20px 80px;
        font-size: 20px;
        font-weight: 700;
        color: white;
        text-transform: uppercase;
        background-color: #8a2be2;
        box-shadow: inset -10px -20px 4px 2px #7a21cd;
      }

      /* pseudo class selector */

      button:hover {
        box-shadow: inset -10px -20px 4px 2px #f0e8f8;
        background-color: #fff;
        color: #8a2be2;
      }
    </style>
  </head>
  <body>
    <div>
      <button>submit</button>
    </div>
  </body>
</html>

Normal Button

pseudo-class-selector.jpg

Using after hover pseudo class effect

pseudo-class-hovering.jpg

Pseudo Element Selector:

Pseudo element selector are also apply some additional specific css on chosen element selector, we use double colon(::) before writing pseudo element selector name.

Here we are using two pseudo element before and after.

Before Pseudo Selector:

When we want injected new child element before existing element, so then we use ::before pseudo element and one is important things here inside pseudo have must write to content property.

Syntax:

::before

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Pseudo Element Selector</title>

    <style>
      div {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1000px;
        height: 700px;
        margin: 0 auto;
        background-color: rgb(185, 186, 186);
      }
      button {
        border: none;
        border-radius: 40px;
        outline: none;
        padding: 20px 80px;
        font-size: 20px;
        font-weight: 700;
        color: white;
        text-transform: uppercase;
        background-color: #8a2be2;
        box-shadow: inset -10px -20px 4px 2px #7a21cd;
      }

      /* before pseudo element selector */

      button::before {
        content: "before";
        width: 100px;
        height: 100px;
        background-color: rgb(248, 244, 43);
        position: absolute;
        transform: translate(-180%, -40%);
        border-radius: 50%;

        text-transform: lowercase;
        color: #8a2be2;
      }
    </style>
  </head>
  <body>
    <div><button>submit</button></div>
  </body>
</html>

before-pseudo-element.jpg

Before Pseudo Selector:

When we want injected new child element before existing element, so then we use ::before pseudo element and one is important things here inside pseudo have must write to content property.

Syntax:

::after

Example:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Pseudo Element Selector</title>

    <style>
      div {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1000px;
        height: 700px;
        margin: 0 auto;
        background-color: rgb(185, 186, 186);
      }
      button {
        border: none;
        border-radius: 40px;
        outline: none;
        padding: 20px 80px;
        font-size: 20px;
        font-weight: 700;
        color: white;
        text-transform: uppercase;
        background-color: #8a2be2;
        box-shadow: inset -10px -20px 4px 2px #7a21cd;
      }

      /* before pseudo element selector */

      /* button::before {
        content: "before";
        width: 100px;
        height: 100px;
        background-color: rgb(248, 244, 43);
        position: absolute;
        transform: translate(-180%, -40%);
        border-radius: 50%;

        text-transform: lowercase;
        color: #8a2be2;
      }*/

      /* after pseudo element selector */

      button::after {
        content: "after";
        width: 100px;
        height: 100px;
        background-color: rgb(248, 244, 43);
        position: absolute;
        transform: translate(90%, -40%);
        border-radius: 50%;
        text-transform: lowercase;
        color: #8a2be2;
      }
    </style>
  </head>
  <body>
    <div><button>submit</button></div>
  </body>
</html>

after.jpg

Thanks for reading our blog, please gives your valuable suggestion.

Ok, Bye and we will meet you in the next blog.