• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 解析CSS编写中的属性优先级问题

解析CSS编写中的属性优先级问题

作者:StephenLee 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS,属性优先级,属性,优先级等相关知识,StephenLee 希望在学习及工作中可以帮助到您

当你将一个样式添加到元素上却发现不起作用时,那就是遇到优先级问题了。那么应该如何处理 CSS 优先级问题呢,下面我总结了一些解决 CSS 优先级问题的常用法则。

样式距离
我们可以通过使用外部样式、内部样式、内联样式等方法给元素添加指定的样式,此时的优先级是:

外部样式 < 内部样式 < 内联样式
这个应该比较容易理解,也就是说离元素距离越近的样式优先级越大。如:

  1. <style type="text/css">   
  2.   div{color:blue;} //内部样式   
  3. </style>   
  4. <link rel="stylesheet" type="text/css" href="mystyle.css"/> //外部样式(color:green)   
  5. <div style="color:red">my color</div>//内联样式  

此时显示的优先级是 red > blue > green。所以 my color 显示为红色。

特殊的计算方法
假设有下面这段代码:

  1. <style type="text/css">   
  2.   div p.classSelector {color: blue}   
  3.   #idselector p {color: red}   
  4. </style>   
  5. <div id="idSelector">   
  6.   <p class="classSelector">my color</p>   
  7. </div>  

我们面对下面的 css,如何判断优先级呢?

  1. <style type="text/css">   
  2.   div p.classSelector {color: blue}   
  3.   #idselector p {color: red}   
  4. </style>  

这里介绍一种特殊的计算方法:

元素, 伪元素: 1 – (0,0,0,1)
类, 伪类, 属性: 1 – (0,0,1,0)
ID: 1 – (0,1,0,0)
内联样式: 1 – (1,0,0,0)
这里的属性指的是:
2016428111405879.jpg (592×158)

效果如下:
2016428111437471.jpg (452×47)

优先级从上往下依次增加,至于如何计算,同样举例说明:

p: 1个元素– (0,0,0,1)
div: 1个元素 – (0,0,0,1)
#idSelector: 1个ID – (0,1,0,0)
div#idSelector: 1个元素, 1个ID – (0,1,0,1)
div#idSelector p: 2个元素, 1个ID– (0,1,0,2)
div#idSelector p.classSelector: 2个元素, 1个类, 1个ID – (0,1,1,2)
所以现在我们再来看上面的例子:

  1. div p.classSelector {color: blue} - (0,0,0,1) + (0,0,0,1) + (0,0,1,0) = (0,0,1,2)   
  2. #idselector p {color: red} - (0,1,0,0) + (0,0,0,1) = (0,1,0,1)  

由于优先级上 (0,1,0,1) > (0,0,1,2),所以我们知道最后显示的颜色为红色。

继承
继承是个比较好理解的概念,即子元素会继承父元素的样式。例如:

  1. <div style="color:red">   
  2.   <p>my color</p>   
  3. </div>  

上例中的 span 会继承父元素 div 的样式。但不是所有的属性都会默认使用继承的方式,比如 margin 和 padding 属性。例如:

  1. <div style="margin:10px;padding:10px">   
  2.   <p>my color</p>   
  3. </div>  

此时,元素 p 并不会继承父元素 div 的 margin 和 padding 样式,除非你这么做:

  1. <div style="margin:10px;padding:10px">   
  2.   <p style="margin:inherit;padding:inherit">my color</p>   
  3. </div>  

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06IE6/7下多种方法移除button、input 默认边框和去掉焦点线
  • 2017-08-06css教程之样式表的基本语法(一)
  • 2017-08-06@keyframes规则实现多重背景的CSS动画
  • 2017-08-06CSS3 开发工具收集
  • 2017-08-06CSS3使用transition实现的鼠标悬停淡入淡出
  • 2017-08-06利用清晰的移动应用表单的设计来抓住用户
  • 2017-08-06css和js实现瀑布流效果示例
  • 2017-08-06CSS3打造百度贴吧的3D翻牌效果示例
  • 2017-08-06CSS div布局需要注意的两点
  • 2017-08-06PNG8格式图片是不支持半透明等问题深入分析

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • CSS 网页布局应该避免滥用div元素
    • 纯CSS绘制漂亮的圆形图案效果
    • CSS属性behavior的语法使用说明
    • css之clearfix的用法深入理解(必看篇)
    • 巧用隐藏和负边距实现兼容所有浏览器的ul和li并列效果
    • CSS3条纹背景制作的实战攻略
    • div三栏布局左中右通过float浮动来设置
    • css串联选择器和后代选择器使用方法
    • 10 套华丽的CSS3 按钮小结
    • IE6下PNG背景透明的七种方法小结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有