css !important使用方法及需要注意的地方

css中!important的作用

我们知道,CSS写在不同的地方有不同的优先级, .css文件中的定义 < 元素style中的属性,但是如果使用!important,事情就会变得不一样。

首先,先看下面一段代码

<Meta http-equiv="Content-Type" content="text/html; charset=utf-8">

测试Css中的!Important区别

测试Css中的Important

虽然元素的style中有testClass类的定义,但是在上面的css定义中的用!important限定的定义却是优先级最高的,无论是在ie6-10或者Firefox和Chrome表现都是一致的,都显示蓝色。

css的优先级以及!important的使用

CSS的优先级应该是作为CSS基本知识而广为知道的,所以CSS入门后,就一直把CSS的优先级记挂在心里(自觉告诉自己这地方很可能会摔跤)。起初可能是因为自己的项目经验不够丰富,或者是自己所接触到的项目都是小规模的前端,也或与自己书写CSS的习惯有关(自己基本上就是逐层书写CSS,尽量把代码写得干净整洁),CSS优先级并没有成为某次项目的绊脚石。直到某次项目,因为用到的CSS库与自己页面的设计稿有冲突,才再次重视起CSS的优先级。

以下就将有关CSS的优先级的知识进行归纳整理:

①继承的不如指定的;②id>class>标签选择符;③越具体的样式越强大;④标签 id>id;标签 class>class。

CSS优先级权重的计算方法:CSS优先级包含四个级别(标签内选择符,ID选择符,Class选择符,元素选择符)以及各级别出现的次数。根据这四个级别出现的次数计算得到CSS的优先级,规则如下:

①元素标签中定义的样式,加1000;

②每个ID选择符,加0100;

③每个Class选择符、每个属性选择符、每个伪类,加0010;

④每个元素选择符或伪元素选择符,加0001;

将这四个数字分别累加,就得到每个CSS定义的优先级的值,然后从左到右逐位比较大小,数字大的CSS样式的优先级高。

举例:

假设对应example.html在example.css文件中定义如下样式:

1. h1{color:red;} /*一个元素选择符,结果为0001*/

2. body h1{color:green;} /*两个元素选择符,结果是0002*/

3. h2.grape{color:purple;} /*一个元素选择符、一个Class选择符,结果是0011*/

4. li#answer{color:navy;} /*一个元素选择符,一个ID选择符,结果是0101*/

而同时在example.html中有:

/*元素标签中定义,一个元素选择符,结果是1001*/

1001是有关h1样式中计算最大的,所以h1元素的颜色应该是蓝色的。

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...