python html5 bootstrap 视频教程
德云社区 门户 IT 编程 编程语言 XML/HTML 查看内容

css 中 !important 的作用与用法

2014-12-4 02:35| 发布者: digitser| 查看: 1813| 评论: 2|原作者: liuliuab1

摘要: css 中 !important 的作用与用法 {*rule !important} 这个 css 规则当今在网页制作的时候的普及已经非常流行了,以前大家对它的理解可能还停留在 ‘浏览器是否识别阶段’ 而没有真正去研究过。众所周知,!importa ...
自动立式分页纸箱赋码系统 ── 全自动 专业 立式分页 瓦楞纸 水性油墨 贴标 喷码 检测系统

       {*rule !important} 这个 css 规则当今在网页制作的时候的普及已经非常流行了,以前大家对它的理解可能还停留在 ‘浏览器是否识别阶段’ 而没有真正去研究过。众所周知,!important 这个规则对IE 6.0、IE 7.0 和 Firefox 能写 hack,现在就来讲解这是什么原理:

  *对于 IE 系列浏览器都能够识别, firefox 浏览器则不能识别;
  !important 只有 IE 7.0 和 firefox 可以识别,但是 IE 6.0 不能成功应用.

  (1)区别 IE 与 firefox 的 hack 为:border:2px solid #f00;*border:1px solid #f00;
  (2)区别 IE 6.0 与 IE 7.0、firefox 的 hack 为:border:1px solid #f00!important;border:2px solid #f00;


  在(1)中,之所以把 * 放在后面是因为 ff 不识别 *而导致只对它设置了一次 border;而 IE 系列进行了两次 border 设置后,后一个属性覆盖了前一个属性,故为一像素的边框。
  在(2)中,之所以把 !important 放在第一个 border 设置,是因为它把这次 border 的优先级提高了,即使后面在一次甚至在 N 次设置家border 也无效,但是 IE 6.0 对这个规则不接受,而导致它应用了第二次的 border 设置,也就是第二次覆盖了第一次的这一原理, 并不是它不识别 !important; 所以它的 border 为 2 像素的红框。

以下是一个简单应用:



无标题文档




例一:
CSS
1 #Box {
2      color:red !important;
3      color:blue;
4 }
HTML
1
在不同的浏览器下,这行字的色应该不同!
这个例子应该是大家经常见到的 important 用法了,在 IE 环境下,这行字是蓝色,在 firefox 下,为红色,其用法不再多说了,看下一个例子。

例二:
CSS

1 #Box div{
     color
:red;
}
2 .important_false
{
     color
:blue;
}
3.important_true
{
     color
:blue !important;
}

HTML

   
这一行末使用important

   
这一行使用了important

  例二中,CSS代码第一行设定了 box 里面所有 div 中字体色为红色,第二行和第三行都用 class 重新定义了自身 div 的字体色为蓝色,不同的是,第二行末使用 important,而第三行使用了!

  默认情况下,class 的优先级小于
important,所以,第二行中即使使用了 class 重定义了自身样式,也无法生效,所以继承父级属性,这行字还是红色!
  但是,第三行中,用了 important 提升优先级(或看成强制重定义),所以这里的 css 得以生效,这行字变为了蓝色!从这个例子,得以证明,IE 对 important 并不是不支持!
  那么为什么很多人都说 IE 不认识它呢?我想应该是大家实战中可能都没有遇到例子中的情况: 当你想提升 class 的优先级时怎么办?

  也就是说大家可能忽略了它的这一作用,只了解在命名为同一个元素的 CSS 代码块中,用它来提升排列顺序相对靠前的代码的优先级(例一)!

  通过上边两个例子,得以总结:

        important对 一个良好(或者是标准)的浏览器来说,不仅仅是从顺序上提升代码的优先级,还可以用来提升 class 的优先级(比如 firefox),但是从 IE 对前者的不支持可以看出,这只是 IE 的一大BUG,而不能说它“不认识、不支持”        

然而,不管怎么样,IE 的这一大 BUG 帮助我们解决了很多兼容性问题,这显然不是件坏事!

        在 IE 中对盒模型(box-model)的解释是有 BUG 的,IE 6.0 之前的版本会把某元素的边框值和填充值包含在宽度之内(而不是加在宽度值上)。例如,你可能会使用以下 css 来指定某个容器的尺寸:
1 #box
2   {
3    width:100px;
4    border:5px;
5    padding:20px;
6   }
  然后在 html 中应用:盒的总宽度在几乎所有浏览器中为 150 像素(100 像素宽度 + 两条 5 像素的边框 + 两个 20 像素的填充),唯独在 IE6 之前版本的浏览器中仍然为 100 像素(边框值和填充值包含在宽度值中),使用盒模型的 hack 可以解决这一问题,
#box
  
{
   width
:150px;        //这个是错误的width,所有浏览器都读到了
   voice-family
: \}\;      //IE5.X/win忽略了\}\后的内容
   voice-family:inherit;
   width:100px;       //包括IE6/win在内的部分浏览器读到这句,新的数值(300px)覆盖掉了旧的
  }
       还有更简单的办法如下:
  CSS:
  #box
{ width:150px; }
  #box div
{ border:5px; padding:20px; }
  HTML:
  ...
  这样一来在任何浏览器中盒的总宽度都将是 150 像素。
  但是即使是到了最新的 IE6.0 依然存在浮动模型(Float-model)的问题,值得庆幸(还是悲哀?)的是我们可以用 IE 中一直都不支持的 !important 来解决这个问题。

  !important 是 CSS1 就定义的语法,作用是提高指定样式规则的应用优先权(参见:W3.org 的解释)。语法格式{ sRule!important },即写在定义的最后面,
     例如:

box{color:red !important;}
  假如我们定义一个这样的样式:
#box{background-color: #ffffff !important; background-color: #000000;}
  那么在支持该语法的浏览器,如 Firefox、Opera 中,能够理解 !important 的优先级,背景显示 #ffffff 颜色,而在 IE 中则显示 #000000。

版权声明:               
本文由 德云社区 整理,原文来自网络。

路过

雷人

握手

鲜花

鸡蛋
AI人工智能 语音助理 人工翻译 教程

相关阅读

发表评论

最新评论

引用 liuliuab1 2014-12-4 01:56
占用
引用 liuliuab1 2014-12-4 01:56
占用

查看全部评论(2)

相关分类

Qt 6.5.1 官方中文文档编制 手册教程 帮助文件 人工翻译
Qt 6.5.1 官方中文文档编制 手册教程 帮助文件 人工翻译 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 Qt 6.5.1。 Qt 6.5.1 中文文档编制[118/2024-10-24]
Qt 6.5.1 官方中文文档编制 手册教程 人工翻译更新日志
Qt 6.5.1 官方中文文档编制 手册教程 人工翻译更新日志 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 Qt 6.5.1。 Qt 6.5.1 中文文档编制采[53/2024-10-24]
数字 Python IDE 2024 注册机 注册码生成器 附详细破解方法
数字 Python IDE 2024 注册机 注册码生成器 附详细破解方法 数字 Python IDE 目前还在不断研发 进步中,虽不太成熟,但其新理念很有特色 特别适于多版本 多文档 多工程并行[51/2024-10-24]
数字翻译 2024 注册机 注册码生成器 内存破解器 附详细用法
数字翻译 2024 注册机 注册码生成器 内存破解器 附详细用法 数字翻译目前还在不断研发 进步中,虽不太成熟,但其新理念很有特色 特别适于 HTML 文档本地化 (面向高精度 超[57/2024-10-24]
数字 Python IDE 2023 注册机 注册码生成器 附详细破解方法
数字 Python IDE 2023 注册机 注册码生成器 附详细破解方法 数字 Python IDE 目前还在不断研发 进步中,虽不太成熟,但其新理念很有特色 特别适于多版本 多文档 多工程并行[49/2024-10-24]
数字翻译 2023 注册机 注册码生成器 内存破解器 附详细用法
数字翻译 2023 注册机 注册码生成器 内存破解器 附详细用法 数字翻译目前还在不断研发 进步中,虽不太成熟,但其新理念很有特色 特别适于 HTML 文档本地化 (面向高精度 超[49/2024-10-24]
CSS3 官方中文文档编制 手册教程 人工翻译 更新日志
CSS3 官方中文文档编制 手册教程 人工翻译 更新日志 CSS3 中文文档编制采用机器辅助 + 全人工翻译,完全采用 数字翻译 的文档翻译流程进行汉化 (未采用任何第 3 方工具),[1624/2022-07-31]
CSS3 官方中文文档编制 手册教程 帮助文件 人工翻译
CSS3 官方中文文档编制 手册教程 帮助文件 人工翻译 CSS3 中文文档编制采用机器辅助 + 全人工翻译,完全采用 数字翻译 的文档翻译流程进行汉化 (未采用任何第 3 方工具),[1846/2022-07-31]
SolidWorks 2020 非对称Conic Rho圆角 抽壳出现模型穿刺
SolidWorks 2020 非对称Conic Rho圆角 抽壳出现模型穿刺 标准对称圆角最常用,但有时偶尔也会用到非对称圆角。 特别是模具、五金、电子、手饰、汽车、家具、玩具、等对圆[1480/2022-05-25]
NumPy 1.22 官方中文文档编制 手册帮助 更新日志
NumPy 1.22 官方中文文档编制 手册帮助 更新日志 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 NumPy 1.22。 NumPy 1.22 中文文档编制采用[1021/2022-05-22]
NumPy 1.22 官方中文文档编制 手册帮助 全人工翻译
NumPy 1.22 官方中文文档编制 手册帮助 全人工翻译 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 NumPy 1.22。 NumPy 1.22 中文文档编制采[1228/2022-05-22]
Pillow 9.1.1 官方中文文档编制 手册帮助 更新日志
Pillow 9.1.1 官方中文文档编制 手册帮助 更新日志 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 Pillow 9.1.1。 Pillow 9.1.1 中文文档编[1075/2022-05-22]
Pillow 9.1.1 官方中文文档编制 手册帮助 全人工翻译
Pillow 9.1.1 官方中文文档编制 手册帮助 全人工翻译 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 Pillow 9.1.1。 Pillow 9.1.1 中文文档[1025/2022-05-22]
PyMuPDF 1.19.6 官方中文文档编制 手册帮助 更新日志
PyMuPDF 1.19.6 官方中文文档编制 手册帮助 更新日志 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 PyMuPDF 1.19.6。 PyMuPDF 1.19.6 中文[1638/2022-05-22]
PyMuPDF 1.19.6 官方中文文档编制 手册帮助 全人工翻译
PyMuPDF 1.19.6 官方中文文档编制 手册帮助 全人工翻译 以后不再上传 en-US 官方原版文档编制,目前上传的最新 zh-CN 人工翻译版本为 PyMuPDF 1.19.6。 PyMuPDF 1.19.6 中[1506/2022-05-22]

Archiver|Sitemap|小黑屋|德云社区   

GMT+8, 2025-1-19 11:39 , Processed in 0.045629 second(s), 28 queries .

工业和信息化部: 粤ICP备14079481号-2

技术支持 乐数软件     版权所有 © 2014-2021 德云社区    

返回顶部