Most technical people are familiar with CSS selectors. For example, suppose you add a class to a P tag, but some of the attributes in that class don’t work after execution. I realized the priority of CSS selectors when I looked at Firebug and found that properties that did not work were overwritten. Strictly speaking, there are three types of selectors: tag name selectors, class selectors, and ID selectors. The so-called descendant selectors and group selectors are just extensions of the first three. Writing style=”” inside the tag should be an introduction to CSS, not a selector, because there is no selector. Generally, people combine these methods together, so they have five or six selectors.

The most basic selectors are element selectors (like div),ID selectors (like #header), and class selectors (like.tweet).

Some unusual selectors include pseudo-class selectors (: hovers), many complex CSS3 and regular selectors, such as first-child and class ^= “grid-“. CSS selectors have efficient inheritance. To quote Steve Souders, the order of CSS selectors’ efficiency from highest to lowest is as follows:

The selector usage
The id selector #myid
Class selectors .myclassname
Label selector div,h1,p
Adjacent selector h1+p
Child selectors ul > li
Descendant selector li a
Wildcard selector *
Property selector a[rel="external"]
Pseudo class selector a:hover, li:nth-child

Even though the ID selector is fast and efficient, it is no more than that. From Steve Souders’ CSS Test, we can see that the speed difference between ID selector and class selector is very, very small.

On Firefox 6 on Windows, I measured a reflow figure of 10.9ms for a simple class selector and 12.5ms for an ID selector, so the ID is actually a little slower than the class selector.

The difference in speed between an ID selector and a class selector is essentially unrelated.

On a test of the label selector (a), it was shown to be much slower than the class or ID selector. On a test of a deeply nested descendant selector, the display data is about 440! From this we can see that the difference between the ID/ class selector and the element/descendant selector is large, but the difference between them is small.

How is the priority of the selector specified?

In general, the more special the selector, the higher its priority. The more accurate the selector is, the higher its priority. Normally we use 1 to indicate the priority of the label name selector, 10 to indicate the priority of the class selector, and 100 to indicate the priority of the ID selector. Polaris span {color:red; } selector priority is 10 + 1, i.e. 11; Polaris has a priority of 10; The browser will naturally display red words. With this in mind, the following priority calculation is a snap:

Span var priority 1+10 +10 +1 Span# XXX. Songs Li Priority 1+100 +10 +1 # XXX Li priority 100 +1Copy the code

The rules for using different selectors are as follows:

  1. Accurately select the label to control;
  2. Use the selector with the most reasonable priority;
  3. Keep your HTML and CSS code simple and beautiful. Usually:

The most common selector is the class selector.

② Li, TD, DD, etc. often appear in a large number of consecutive, and the same or similar style tag, we use the class selector with the tag name selector combined with the descendant selector. Xx Li/TD/DD {} way to select.

③ ID selectors are rarely used. Of course, many front-end developers prefer ID selectors for header, footer, banner, and conntent because the same style cannot be used twice on a page.

Here we have to mention that CSS is written in the same way as CSS inside the tag:

<div style="color:red">polaris</div>

This is when the priority is highest. We give it a priority of 1000, which is not recommended, especially for beginners. This also completely contradicts the idea of separating content from display. The benefits of DIV+CSS are no longer evident.


How to improve CSS selector performance?

1. Avoid generic selectors

.content {color: red; }

The browser matches all elements in the document and then matches each element with class content up to the root node of the document. Therefore, the matching overhead is very high, so avoid the case where the key selector is a wildcard selector.

2. Avoid limiting id selectors with labels or class selectors

Avoid the use of

Button# backButton {... }

Avoid the use of

The menu - left# newMenuIcon {... }

It is recommended to use

# backButton {... }

It is recommended to use

# newMenuIcon {... }

3. Avoid using labels to restrict class selectors

Avoid the use of

Treecell. Indented {... }

It is recommended to use

The treecell - indented {... }

The optimal use of

The hierarchy - deep {... }

4. Avoid using multiple label selectors. Use class selector instead to reduce CSS lookups

Avoid the use of

Treeitem [mailFolder ="true"] > Treerow > treecell {... }

It is recommended to use

The treecell - mailfolder {... }

5. Avoid child selectors

Avoid the use of

Treehead treerow treecell {... } BETTER, BUT STILL BAD treehead > treerow > treecell {... }Copy the code

It is recommended to use

The treecell - the header {... }

Use inheritance

Avoid the use of

#bookmarkMenuItem > .menu-left { list-style-image: url(blah) }

It is recommended to use

#bookmarkMenuItem { list-style-image: url(blah) }


Simple and efficient CSS

Efficient CSS means that the browser does as little searching as possible when looking for elements that match the style. Here are some of the most common mistakes we make when writing CSS:

Do not use tag names before ID selectors

Commonly written: DIV#divBox

Better: #divBox

Explanation: Because the ID selector is unique, adding div increases unnecessary matches.

Do not use label names in front of class selectors

Common writing: span. Red

Better written:.red

Explanation: Same as the first rule, but if you define more than one.red, and the style is different for different elements, do not remove it, such as in your CSS file:

p.red{color:red; }

span.red{color:#ff00ff}

If that’s the way it’s defined, don’t take it out, because if you take it out, you’ll get confused, but it’s probably best not to do that

Use hierarchies as little as possible

#divBox p. red{color:red; }

Better written:.red{.. }

Use class instead of hierarchy

#divBox ul li a{display:block; }

.block{display:block; }


30 classes of CSS selectors you must remember

You probably know about the “ID,” “class,” and “descendant” selectors, and you’re using them in general, so you’re making the mistake of having a much higher level of selection flexibility. Most of the selectors mentioned below are under the CSS3 standard, so they only work with the latest version of the browser, so you should keep that in mind.

1. *

*{ margin: 0; padding: 0; }Copy the code

Before we look at more advanced selectors, we should recognize the well-known empty selector. The asterisk will select every element on the page. Many developers use it to clear margin and padding. Of course you can use this in practice, but I don’t recommend using it in production. It adds a lot of unnecessary stuff to the browser. * can also be used to select all children of an element.

#container * { border: 1px solid black; }Copy the code

It will select all elements under # Container. Of course, I still don’t recommend using it, if at all.

compatibility

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

2. #X

#container { width: 960px; margin: auto; }Copy the code

Use # in the selector to locate an element with an ID. You use it all the time, and you have to be very careful with it. Ask yourself: do I have to assign an ID to this element to locate it?

The ID selector is very strict and you can’t reuse it. If possible, try using tag names first, new elements in HTML5, or pseudo-classes.

compatibility

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

3. .X

.error { color: red; }Copy the code

This is a class selector. It differs from the ID selector in that it can locate multiple elements. You can use class when you want to style multiple elements. When you want to modify a particular element that’s where you locate it with an ID.

compatibility

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

4. X Y

li a { text-decoration: none; }Copy the code

The next common one is the descendant selector. If you want to be more specific about locating elements, you can use it. For example, what if, instead of locating all the A elements, you only needed to locate the A tag under the LI tag? This is where you need to use the descendant selector.

Expert tip: If your selector looks like X, Y, Z, A, b, ror, you’re wrong. Keep reminding yourself that you really need to retouch that many elements.

compatibility

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

5. X

a { color: red; }

ul { margin-left: 0; }
Copy the code

If you want to locate all the tags on a page, not by ID or ‘class’, it’s easy, just use the type selector.

compatibility

  • IE6+
  • Firefox
  • Chrome
  • Safari
  • Opera

6. X:visited and X:link

a:link {color:red; } a:visited {color: purple; }Copy the code

We use the :link pseudo-class to locate all links that have not yet been visited.

In addition, we also use :visited to locate all the links that have been visited.

compatibility

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

7. X+Y

ul + p { color: red; }Copy the code

This is called the adjacent selector. It directs the selection of the immediate successors of the specified element. The example above is to select the first paragraph after all ul labels and set their color to red.

compatibility

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

8. X>Y

div#container > ul { border: 1px solid black; }Copy the code

The difference between X, Y and X > Y is that the conductor in the back chooses its immediate child. Look at the following example:

<div id="container"> <ul><li> List Item <ul><li> Child </li> </ul></li><li> List Item </li><li> List Item </li><li> List  Item </li></ul> </div>Copy the code

#container > ul only selects all direct UL elements under div with id ‘container’. It will not locate the ul element under the first LI.

For some reason, there are a number of performance advantages to using child node combinatorial selectors. In fact, this is highly recommended when using CSS selectors in javascript.

compatibility

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

9. X ~ Y

ul ~ p { color: red; }Copy the code

The sibling combinatorial selector is similar to X+Y, but it’s not so strict. The UL + P selector selects only those elements immediately following the specified element. The selector, in turn, selects all matching elements following the target element.

compatibility

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

10. X[title]

a[title] { color: green; }Copy the code

This is called the property selector, and in this example, only the elements with the title attribute are selected. Anchor tags that do not have this attribute will not be decorated by this code. Think again if you want to be more specific? That…

compatibility

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

11. X[href=”foo”]

a[href="http://strongme.cn" rel="external nofollow" target="_blank" ] {
color: #1f6053; /* nettuts green */}

Copy the code

This code sets anchor tags with href value of [http://strongme.cn](http://strongme.cn/) to green, leaving the rest of the tags unaffected.

Notice that we enclose the values in double quotes. Use double quotes when using Javascript. Use standard CSS3 selectors whenever possible.

This works, but it’s still a bit dead. If it’s a similar link instead of this one, then regular expressions are used.

compatibility

  • IE7+
  • Firefox
  • Chrome
  • Safari
  • Opera

12. X[href=”strongme”]

a[href="strongme"] { color: #1f6053; }Copy the code

Tada is exactly what we need, which specifies that the strongme value must appear in the href attribute of the anchor tag, whether strongme.cn or strongme.com or www.strongme.cn can be selected. But remember this is a very broad expression. If the anchor tag points to a site other than strongMe, to be more specific, use ^ and $to indicate the beginning and end of the string, respectively.

compatibility

  • IE7+

  • Firefox

  • Chrome

  • Safari

  • Opera

13. X[href^=”href”]

a[href^="http"] {

background: url(path/to/external/icon.png) no-repeat;

padding-left: 10px; }
Copy the code

I’m sure you’ve all wondered, and I’m sure you’ve seen, that some sites have an external chain icon next to the anchor tag. This design makes it very clear that you are going to go to another site. It’s easy to do with carat symbols. It is usually used to identify the beginning in a regular expression. If we wanted to locate the tag starting with HTTP in the anchor attribute href, we could use similar code.

Notice that we didn’t search for http://, which is unnecessary because it doesn’t include https://.

What if we want to find all the anchor tags that point to an image? So let’s use the ampersand character.

compatibility

  • IE7+

  • Firefox

  • Chrome

  • Safari

  • Opera

14. X[href$=”.jpg”]

a[href$=".jpg"] {

color: red; }
Copy the code

This time we use the regular expression $to represent the end of the string. This code just means to search for all image links, or other links that end in.jpg. But remember that this notation does not work for GIFS and PNGS.

compatibility

  • IE7+

  • Firefox

  • Chrome

  • Safari

  • Opera

15. X[data-*=”foo”]

a[data-filetype="image"] { color: red; }Copy the code

Going back to item 8, how do we select all image types PNG, JPEG,’ JPG ‘,’ GIF ‘? We can use multiple selectors. See the following:

a[href$=".jpg"],

a[href$=".jpeg"],

a[href$=".png"],

a[href$=".gif"] {

color: red; }
Copy the code

But that would be a pain to write, and it would be very inefficient. Another option is to use custom properties. We can add a data-fileType attribute to each anchor to specify the type of image the link points to. [HTML] Image Link With this hook, we can use the standard method to select only the anchors whose file type is Image.

a[data-filetype="image"] {

color: red; }
Copy the code

compatibility

  • IE7+

  • Firefox

  • Chrome

  • Safari

  • Opera

16. X[foo~=”bar”]

a[data-info~="external"] {

color: red; }

a[data-info~="image"] {

border: 1px solid black; }
Copy the code

I think this is gonna make your little friend say “Wow”. Very few people know this trick. The ~ symbol can locate tags whose attribute value is a space-separated multiple value. Continuing with the example in article 15, we can set a data-info property that can be used to set any space-separated value we want. In this example we will indicate them as external links and image links.

Click Me, Fool

After setting this flag for the elements, we can use ~ to locate the tags.

/ Target data-info attr that contains the value "external" / a[data-info~="external"] { color: red; } / And which contain the value "image" / a[data-info~="image"] { border: 1px solid black; }Copy the code

17. X:checked

input[type=radio]:checked {

border: 1px solid black; }
Copy the code

The above pseudo-class notation locates checkboxes and checkboxes that are checked, and that’s it.

compatibility

  • IE9+

  • Firefox

  • Chrome

  • Safari

  • Opera

18. X:after

Before and after are pseudo-classes. It seems like every day people find creative ways to use them. They generate some content around the selected tag. Many properties are used for the first time when using the. Clear-fix technique.

.clearfix:after {

    content: "";

    display: block;

    clear: both;

    visibility: hidden;

    font-size: 0;

    height: 0;

  }

.clearfix { 

   display: inline-block; 

   _height: 1%;

}
Copy the code

The code above fills in a blank space after the target tag and then clears it. This is one you have to keep in your cornucopia. This is especially useful when the Overflow: Hidden method doesn’t work.

According to the CSS3 standard, two colons :: can be used. Browsers will also accept double quotes for compatibility. Actually, in this case, a colon might be wise.

compatibility

  • IE8+

  • Firefox

  • Chrome

  • Safari

  • Opera

19. X:hover

div:hover {

background: #e3e3e3; }
Copy the code

Needless to say, everyone knows it. The official term is User Action pseudo class. It sounds a little confusing, but it’s fine. If you want to paint over the user’s mouse, this pseudo-class method will do the trick.

Note that older versions of IE only work with the: Hover pseudo-class attached to the anchor point A tag.

It’s usually used when you hover over an anchor link and add a border.

a:hover {

 border-bottom: 1px solid black;

}
Copy the code

Border-bottom :1px solid black; Than the text – decoration: underline; It looks a lot better.

compatibility

  • IE6+(IE6 only works on anchor tags)

  • Firefox

  • Chrome

  • Safari

  • Opera

20. X:not(selector)

div:not(#container) {

   color: blue;

}
Copy the code

It is quite useful to take antipseudo-classes, assuming that we want to select all div tags except those with the ID container. That’s what the above code does.

Or I want to select all the tags except the outgoing paragraph tags.

:not(p) {

  color: green;

}
Copy the code

compatibility

  • IE9+

  • Firefox

  • Chrome

  • Safari

  • Opera

21. X::pseudoElement

p : : first-line { font-weight: bold; The font - size: 1.2 em. }Copy the code

We can use :: to select part of a tag, such as the first paragraph, or the first word. But remember to use block tags for this to work.

A false label consists of two colons ::.

Locate the first word

p::first-letter {

   float: left;

   font-size: 2em;

   font-weight: bold;

   font-family: cursive;

   padding-right: 2px;

}
Copy the code

This code finds all paragraphs on the page and specifies the first word of each paragraph.

It is often used in newspapers and magazines to highlight content.

Locate the first line of a paragraph

p::first-line { font-weight: bold; The font - size: 1.2 em. }Copy the code

Similar to ::first-line, the first line of the paragraph is selected.

For compatibility, older browsers also supported single colons, such as :first-line,:first-letter,:before,:after. However, this compatibility does not apply to the newly introduced features.

compatibility

  • IE6+

  • Firefox

  • Chrome

  • Safari

  • Opera

22. X:nth-child(n)

li:nth-child(3) {

   color: red;

}
Copy the code

Remember the days when we had no idea how to get to the first element of a pushdown tag? Gone are the days with nTH-Child.

Note that nTH-Child takes an integer argument, and then it does not start at zero. If you want to get the second element then you pass li:nth-child(2).

We can even get a number of subtags defined by the variable name. For example, we can use Li :nth-child(4n) to fetch labels every third element.

compatibility

  • IE9+

  • Firefox3.5 +

  • Chrome

  • Safari

23. X:nth-last-child(n)

li:nth-last-child(2) {

   color: red;

}
Copy the code

If you have N more elements in a UL tag, and you only want to fetch the last three elements, even if this is li: nth-Child (397), you can replace it with the nTH-Last-Child pseudo-class.

This TIP can correctly replace TIP 16, except that it starts at the end and goes backwards.

compatibility

  • IE9+

  • Firefox3.5 +

  • Chrome

  • Safari

  • Opera

24. X:nth-of-type(n)

ul:nth-of-type(3) {

   border: 1px solid black;

}
Copy the code

Once upon a time, we didn’t want to select child nodes, we wanted to select them based on the type of element.

Imagine having five UL labels. If you only want to modify the third of these, and you don’t want to use the ID attribute, then you can use the nTH-of-Type (n) pseudo-class to do this. In the code above, only the third UL tag will be framed.

compatibility

  • IE9+

  • Firefox3.5 +

  • Chrome

  • Safari

25. X:nth-last-of-type(n)

ul:nth-last-of-type(3) {

   border: 1px solid black;

}
Copy the code

Similarly, you can use nTH-last-of-type to retrieve labels in reverse order.

compatibility

  • IE9+

  • Firefox3.5 +

  • Chrome

  • Safari

  • Opera

26. X:first-child

ul li:first-child {

   border-top: none;

}
Copy the code

This structured pseudo-class can be selected to the first child tag, and you’ll often use it to pull out the first and last borders.

If you have a list, and each label has a top and bottom border, then the effect of the first and last tabs will look a little strange. This is where the pseudo-class can be used to handle the situation.

compatibility

  • IE7+

  • Firefox

  • Chrome

  • Safari

  • Opera

27. X:last-child

ul > li:last-child {

   color: green;

}
Copy the code

In contrast to first-child, last-child takes the last tag of the parent tag.

Such as labels

 List Item    

 List Item 

 List Item 
Copy the code

There’s nothing there. It’s just a List.

ul {

 width: 200px;

 background: #292929;

 color: white;

 list-style: none;

 padding-left: 0;

}

li {

 padding: 10px;

 border-bottom: 1px solid black;

 border-top: 1px solid #3c3c3c;

}
Copy the code

The code above sets the background color, removes the browser’s default inside margin, and sets a border for each LI to highlight some depth.

compatibility

  • IE9+

  • Firefox

  • Chrome

  • Safari

  • Opera

28. X:only-child

div p:only-child {

   color: red;

}
Copy the code

To be honest, you’ll find that you almost never use this pseudo-class. However, it is available and will be needed.

It allows you to retrieve parent tags that have only one child tag. As in the above code, only the div of a paragraph tag is colored.

 My paragraph here. 

 Two paragraphs total. 

 Two paragraphs total. 
Copy the code

In the example above, the second div is not selected. Once the first div has multiple sub-paragraphs, this is no longer useful.

compatibility

  • IE9+

  • Firefox

  • Chrome

  • Safari

  • Opera

29. X:only-of-type

li:only-of-type {

   font-weight: bold;

}
Copy the code

Structural pseudo-classes can be used very cleverly. It will locate the target of a tag that has only one child tag. Suppose you want to get a UL tag that has only one child tag?

Using UL LI will check all li labels. Only of type is used.

ul > li:only-of-type {

   font-weight: bold;

}
Copy the code

compatibility

  • IE9+

  • Firefox 3.5 +

  • Chrome

  • Safari

  • Opera

30. X:first-of-type first-of-type

The pseudo class can select the first sibling of the specified tag.

test

My paragraph here.    

 List Item 1   

 List Item 2       

 List Item 3     

 List Item 4 
Copy the code

So you take out the List Item 2, if you’ve already taken it out or you’ve given up, and you continue.

Solution 1 there are many ways, let’s look at some more convenient. The first is first-of-type.

ul:first-of-type > li:nth-child(2) {

   font-weight: bold;

}
Copy the code

Find the first UL tag, then the direct child tag Li, then the second child node. Solution 2 Another solution is the neighborhood selector.

p + ul li:last-child {

   font-weight: bold;

}
Copy the code

In this case, find the direct UL label under P, and then find its last direct sublabel.

Solution 3 We can play around with these selectors. Take a look at:

ul:first-of-type li:nth-last-child(1) {

   font-weight: bold;

}
Copy the code

Get the first UL tag on the page and then find the last subtag.

compatibility

  • IE9+

  • Firefox 3.5 +

  • Chrome

  • Safari

  • Opera

conclusion

I am currently on the job front-end development, if you also want to learn front-end development technology, in the process of learning the beginning of the front-end, you can meet any problems about learning methods, learning routes, learning efficiency and other aspects, you can apply to join my front-end learning exchange skirt: the front is 4213, and the back is 74697. Inside gathered some are learning front-end beginners, career change, the first stage, I also have here I do front-end technology this time sorted out some front-end learning mind map, front-end factory interview questions, front-end source development tutorial, PDF document books tutorial, if you need to find skirt pig access.

If you want to compromise with older browsers, like IE6, you’ll have to be careful with these new selectors. But don’t let IE6 stop you from learning these new skills. Then you’re being cruel to yourself. Check the compatibility list, or use Dean Edward’s Excellent IE9.js script to make your browser have these features.

Second, when using jQuery, try to use the native CSS3 selector. It may make your code run fast. This allows the selector engine to use the browser’s native parser instead of the selector’s own.