extend is a less pseudo class which extends other selector styles in one selector by using :extend selector.
example
the following example demonstrates the use of extend in the less file −
extend_syntax.htm
<!doctype html> <head> <link rel = "stylesheet" href = "style.css" type = "text/css" /> </head> <body> <div class = "style"> <h2>welcome to tutorialspoint</h2> <p>hello!!!!!</p> </div> </body> </html>
next, create the style.less file.
style.less
h2 { &:extend(.style); font-style: italic; } .style { background: green; }
you can compile the extend.less file to extend.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
h2 { font-style: italic; } .style, h2 { background: blue; }
output
follow these steps to see how the above code works −
save the above html code in the extend_syntax.htm file.
open this html file in a browser, the following output will get displayed.

extend syntax
extend is placed into ruleset or attached to a selector. it is similar to a pseudo class containing one or more classes, which are separated by comma. using the optional keyword all, each selector can be followed.
example
the following example demonstrates the use of extend syntax in the less file −
extend_syntax.htm
<!doctype html> <head> <link rel = "stylesheet" href = "style.css" type = "text/css" /> </head> <body> <div class = "style"> <h2>welcome to tutorialspoint</h2> <div class = "container"> <p>hello!!!!!</p> </div> </div> </body> </html>
now create the style.less file.
style.less
.style:extend(.container, .img) { background: #bf70a5; } .container { font-style: italic; } .img { font-size: 30px; }
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
.style { background: #bf70a5; } .container, .style { font-style: italic; } .img, .style { font-size: 30px; }
output
follow these steps to see how the above code works −
save the above html code in the extend_syntax.htm file.
open this html file in a browser, the following output will get displayed.

the following table lists all the types of extend syntax which you can use in less −
sr.no. | types & description |
---|---|
1 |
extend attached to selector
extend is connected to a selector which looks similar to a pseudo class with selector as parameter. |
2 |
extend inside ruleset
the &:extend(selector) syntax can be put inside the body of ruleset. |
3 |
extending nested selectors
nested selectors are matched using the extend selector. |
4 |
exact matching with extend
by default, extend looks for the exact match between the selectors. |
5 |
nth expression
the form of nth expression is important in extend otherwise, it treats selector as different. |
6 |
extend "all"
when the keyword all is identified at last in the extend argument then less matches that selector as part of another selector. |
7 |
selector interpolation with extend
the extend can be connected to interpolated selector. |
8 |
scoping/extend inside @media
extend matches the selector only that is present inside the same media declaration. |
9 |
duplication detection
it cannot detect the duplication of selectors. |
following are the types of use cases for extend
sr.no. | types & description |
---|---|
1 |
classic use case
classic use case is used to avoid adding the base class in less. |
2 |
reducing css size
extend is used to move the selector as far as the properties you want to use; this helps in reducing the css generated code. |
3 |
combining styles/ a more advanced mixin
using extend we can combine the same styles of a particular selectors into other selector. |