Collect Dots

Some cool CSS selectors’ addition in selectors level 4 – The future

CSS selector level 4 image - realityonweb.com The web is constantly evolving, Some modules of CSS3 has just started making its way, specs are still in development process and more advance level CSS modules have been drafted to evolve it further, which is being referred as “Selectors level 4”. Selectors have been with us since the beginning of CSS. Most awaited selector of level 4 is; Parent Selector of a given element. This advance selector will offer the possibility to target parent of any element without javaScript. There are many such new cool selectors in this level that make website management easier.

Selectors level 4 specification is an evolving draft, not yet an official standard. You can’t rely on draft document as it may change in the future.

Parent selector

There was no way to select the parent container in CSS but in the W3C draft of selectors level 4, parent selector has been introduced. You can select element other than the last one. Now, it’s easy to style the fieldset on the focus of an input element.

$fieldset input:focus{
   background: #e1e1e1;
}

Any syntax of CSS selectors level 4 mentioned here, could be changed. It’s only a draft. Like “$” symbol before the selector [$fieldset], it was proposed in the first draft which got changed to “!” exclamation mark after the selector [fieldset!]

Logical combinator – :matches, :not

It takes the selectors list as an argument and apply the styles.

/* Basic simple use*/
a:link, a:hover, a:visited, a:focus{
   color:green;
}

/* can be written as */
a:matches(a:link, a:hover, a:visited, a:focus){
   color:green;
}

/*more better use*/
h1:matches(.section1, .section2, .section3){
    background: red;
}

/*same with negation*/
h1:not(.section1, .section2, .section3){
    background: black;
}

Location pseudo-classes- :any-link, :local-link

This controls the styling of link more smartly, any-link combine the a:link and a:visited link into one. And using local-link, you can get a different link style of any specific page or based on the domain.

a:link,
a:visited {
  color: green;
}

/*same can be written as*/

a: any-link {

    color: green;

}

Grid-structural pseudo classes – :column, :nth-column, :nth-last-column

Applying style to a column in a grid will be possible in CSS selector level 4. Imagine a grid with different plan options and a specific column (plan) need to be highlighted.

:column(.highlighted) {
  background: yellow;
}
/*alternate column color*/
:nth-column(even) {
  background: gray;
}

If there is not sufficient implementer interest, some features may be dropped during the CR period

Conclusion

Addition of these cool selectors is really mouth-watering but It will take some time to standardize these specifications. At least we will have to wait till the browser vendors start implementing these features. This speedy evolution of the web making it more interesting and dynamic.

Some good resources

About the author


GOPAL JUNEJA Avatar

Comments

10 responses to “Some cool CSS selectors’ addition in selectors level 4 – The future”

  1. I had to read this, thx for putting it together. I agree, some mouth-watering things to come. With CSS3 and HTML5 you can do more without requiring JS, etc … such as animations, graphics. With these selectors getting cleverer and having more options to traverse/filter out a dom, it’s exciting man.

  2. Martin Rinehart Avatar
    Martin Rinehart

    Selectors 4 is here: http://dev.w3.org/csswg/selectors4/

    We may be using LESS/SASS for a while, yet. From the spec: “This module is a somewhat-unstable Working Draft. If you are looking for a stable Selectors specification, use Selectors 3.”

    Via LinkedIn

  3. Mike Wilcox Avatar
    Mike Wilcox

    The parent selector is huge. There were performance issues which kept the from implementing it earlier – I guess they figured it out.

    Via – LinkedIn

  4. Charlie Williams Avatar
    Charlie Williams

    I like the ““If there is not sufficient implementer interest, some features may be dropped during the CR period”
    Why would anyone not want those 4 features to be implemented? Parent selector would be fantastic, especially on CMSs.

  5. Christian Ziebarth Avatar
    Christian Ziebarth

    There’s a weird conundrum that occurs in the overall world of web development where browsers will implement a feature on a test basis and say, “We’ll remove it if nobody uses it,” and developers say, “We can’t use it because nobody uses it.”

  6. Michael Coleman Avatar
    Michael Coleman

    Very nice! Love the selecting of parent elements. I wish they would throw in some mix-ins to help bridge the gaps a bit between processed CSS and pure CSS. Even variables would be nice.

    But I wonder how many different ways IE will mess this up for everyone.

  7. Theresa Barisonek Hoskins Avatar
    Theresa Barisonek Hoskins

    Speaking of IE messing things up,as the numbers of IE users continually decreases and Chrome climbs, how meticulous are your development hacks for IE 9 and below? Yes, there are still those users out there.

  8. Norbert de langen Avatar
    Norbert de langen

    That parent selector is going to be so awesome! But there’s another thing that CSS desperately needs, a native .extend

  9. Chandrakanth Komatireddy Avatar
    Chandrakanth Komatireddy

    Can anyone tell what is the main use of :past ,:future and :current pseudo elements in css4.?
    And the exact Browser versions which support css4 selectors.?

    1. @Chandrakanth: First to clear, there is no CSS4. These are the advance level modules which is called CSS selectors level 4.

      :past, :future and :current pseudo elements are time-dimensional Pseudo-classes. It’s in the working draft stage. I don’t think for now, there is any browser support for these pseudo elements.

Leave a Reply

Your email address will not be published. Required fields are marked *