Understanding of CSS selector weight (personal test)

Understanding of CSS selector weight (personal test)


Copy code
The code is as follows:

<style type="text/css">
div.ui_infor p {font-size: 16px;}
.ui_infor p {font-size: 14px;}
</style>


Copy code
The code is as follows:

<div class="ui_infor">
<p>test of css</p>
</div>

In the above example, the final display effect is font-size: 16px, not the following font-size: 14px;
This combination of selectors has a quick method to judge:
0,0,0,0
The first digit represents the style written on the label, such as

Copy code
The code is as follows:

<p style="font-size: 14px;"></p>

The second digit represents the id selector, such as #demo {}
The third digit represents: class name (.demo {}) or pseudo class (:hover) or attribute selector [rel="xx"]
The fourth digit represents: tag selector p {}
Now let’s practice with the first example:

Copy code
The code is as follows:

div.ui_infor p {font-size: 16px;}

Its weights are: 0,0,1,2

Copy code
The code is as follows:

.ui_infor p {font-size: 14px;}

Its weights are: 0,0,1,1
Result: 0,0,1,2 > 0,0,1,1, so font-size: 16px is displayed;
Supplement: !important has the highest weight, so there is no need to judge, but it will cause a bug in IE-6 browser.
example:

Copy code
The code is as follows:

p {font-size: 18px !important;font-size: 12px;}

In IE-6 browser, font-size: 12px is displayed. Some information on the Internet says that IE-6 does not support !important, which is actually wrong.
Let’s look at an example:

Copy code
The code is as follows:

p {font-size: 18px !important;}
p {font-size: 12px;}

In IE-6, font-size: 18px is displayed, which means that IE-6 supports !important, but the performance is a bit weird. The weird thing is that the !important attribute is overwritten by the latter style with the same name.
For example, in the example p {font-size: 18px !important;font-size: 12px;}, font-size: 12px overrides font-size: 18px !important.
Using this quirk, you can implement "min-height" in IE-6 without using CSS_hack

Copy code
The code is as follows:

p { min-height: 50px; height:auto !important; height:50px;}

<<:  Introduction to the process of extending the boot partition in Kylin 4.0.2 (Ubuntu)

>>:  MySQL tutorial thoroughly understands stored procedures

Recommend

Interviewers often ask questions about React's life cycle

React Lifecycle Two pictures to help you understa...

Nginx/Httpd reverse proxy tomcat configuration tutorial

In the previous blog, we learned about the usage ...

Docker Swarm from deployment to basic operations

About Docker Swarm Docker Swarm consists of two p...

VMware12 installs Ubuntu19.04 desktop version (installation tutorial)

1. Experimental description In the virtual machin...

How to install openssh from source code in centos 7

Environment: CentOS 7.1.1503 Minimum Installation...

Recommended tips for web front-end engineers

Let's first talk about the value of web front...

MySQL Series 12 Backup and Recovery

Table of contents Tutorial Series 1. Backup strat...

javascript realizes 10-second countdown for payment

This article shares the specific code of javascri...

HTML solves the problem of invalid table width setting

If you set the table-layer:fixed style for a tabl...

vue+ts realizes the effect of element mouse drag

This article example shares the specific code of ...

MySQL json format data query operation

The default table name is base_data and the json ...

3 functions of toString method in js

Table of contents 1. Three functions of toString ...

Detailed tutorial for downloading, installing and configuring MySQL 5.7.27

Table of contents 1. Download steps 2. Configure ...