Home >Web Front-end >CSS Tutorial >Deep understanding of CSS selector priority order
There are many selectors in CSS, such as class selectors, tag selectors, ID selectors, etc. The priority order of different selectors is also different. Today I will talk to you about the priority of CSS selectors. Friends in need can refer to the order, and the use of !important. I hope it will be useful to you.
1. !important indicates the highest priority . IE6 browser does not recognize !important .
Example:
Under normal circumstances, the style written below has a higher priority than the style above
demo1{ color:red; color:green; /*绿色的优先级高于红色,所有浏览器都会显示绿色*/ }
If !important is added, its priority will be higher. IE6 is relatively stupid and I don’t know it.
demo2 { color:red !important; /*除了ie6,其他浏览器会认为红色优先级高,显示红色字体*/ color:green; /*ie6浏览器则顺序读取css所以显示绿色*/ }
But note that ie6 does not recognize the priority of !important, but it does not mean that ie6 does not recognize the style attribute with !important.
demo3{ color:red; color:green !important; /*包括ie6,所有浏览器都显示绿色字体,ie6只是不认识优先级罢了*/ }
2. CSS (Cascading Style Sheets) cascading style sheets. In practical applications, there are generally three cascading methods.
Priority: Inline style sheet (inside the tag) > Embedded style sheet (in the current file) > External style sheet (in the external file).
1. External style (applied to multiple web pages)
In the external style sheet, the CSS code is stored as a separate file. For example, the style.css file contains all styles. External cascading in HTML is introduced using the 2cdf5bf648cf2f33323966d7f58a7f3f tag or the @import statement.
The sample code is as follows:
<link rel="stylesheet" href="style.css" type="text/css" /> //link 链接 @import url("style.css"); //@import 导入
2cdf5bf648cf2f33323966d7f58a7f3f The similarities and differences between @import and @import can be found in its article
2. Inline (applied to the current page)
The CSS code of the portal website is usually embedded, which is commonly known as inline style (Inline Style), which uses the c9ccee2e6ea535a969eb3f532ad9fe89 tag to define the style as an internal block object.
The sample code is as follows:
<style type="text/css"> body{font-family:Arial,Helvetica,sans-serif;} </style>
Inline CSS can effectively reduce HTTP requests, improve page performance, and relieve server pressure. Since the browser can only render the page after loading the CSS, it can prevent the CSS file from being read and causing the page to run naked.
3. Embedded (applied to specific tags)
The most basic way of writing CSS is to add code directly to the modified markup element.
The sample code is as follows:
<div style="font-family:Arial,Helvetica,sans-serif;">饿了么</div>
Although this is more intuitive, it greatly increases the page size and does not conform to the design idea of separation of structure and performance.
3. When the weights are different, the browser determines which selector css style to use based on the weight. The style with the higher weight will be used.
Weight rules: The weight of label (P, span) is 1, the weight of class selector is 10, and the weight of id selector is up to 100.
Example:
div {color: red;} /*Tag, weight is 1*/
div span {color: green;} /*Two tags , the weight is 1 1=2*/
div>span {color: purple;} /*The weight is the same as above, so the proximity principle is adopted*/
.main {color : white;} /*Class selector, weight value is 10*/
div span.warning {color: purple;} /*Weight value is 1 1 10=12*/
#main .con p {color: yellow;} /*The weight is 100 10 1=111*/
The above is the detailed content of Deep understanding of CSS selector priority order. For more information, please follow other related articles on the PHP Chinese website!