LESS Tutorial on LESS Parent Selectors

in this chapter, let us understand how parent selectors work. it is possible to reference the parent selector by using the &(ampersand) operator. parent selectors of a nested rule is represented by the & operator and is used when applying a modifying class or pseudo class to an existing selector.

the following table shows the types of parent selector −

sr.no. types & description
1 multiple &

the & will represent the nearest selector and also all the parent selectors.

2 changing selector order

prepending a selector to the inherited (parent) selectors is useful when selector ordering is changed.

3 combinatorial explosion

the & can also produce all the possible permutation of selectors in a list separated by commas.

example

the following example demonstrates the use of parent selector in the less file −

<!doctype html>
   <head>
      <link rel = "stylesheet" href = "style.css" type = "text/css" />
      <title>parent selector</title>
   </head>

   <body>
      <h2>welcome to tutorialspoint</h2>
      <ul>
         <li><a>sass</a></li>
         <li><a>less</a></li>
      </ul>
   </body>
</html>

next, create the style.less file.

style.less

a {
   color: #5882fa;
   &:hover {
      background-color: #a9f5f2;
   }
}

you can compile the style.less file to style.css by using the following command −

lessc style.less style.css

execute the above command; it will create the style.css file automatically with the following code −

style.css

a {
   color: #5882fa;
}

a:hover {
   background-color: red;
}

in the above example, & refers to selector a.

output

follow these steps to see how the above code works −

  • save the above html code in the parent_selector1.htm file.

  • open this html file in a browser, the following output will get displayed.

less parent selector

the parent selectors operator has many uses like, when you need to combine the nested rule's selectors in other way than the default. another typical use of & is to generate class names repeatedly. for more information click here.