• 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中的选择器优先级顺序

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

本文主要包含CSS,选择器等相关知识,牧歌_ 希望在学习及工作中可以帮助到您

特殊性是什么
在对一个HTML元素应用CSS样式时,常常有很多种方法可以找到元素,比如:

  1. <div id="container" class="wrap_sty">   
  2.     <p class="pra">这是一个段落</p>   
  3. </div>   
  4. <style>   
  5.     #container p { color:red }   
  6.     div p { color:green }   
  7.     p { color:yellow }    
  8. </style>  

可见,如果要作用到一个HTML元素的方法有很多,远远不止这些。那么如果一个元素被应用了很多同样的样式,最终会显式到哪一个样式呢?CSS对于多个选择器的优先性使用了一个叫做特殊性的方式。

CSS特殊性
选择器的特殊性分为4个等级,a b c d,从左到右,越左边的越优先, 如果一个选择器规则有多个相同类型选择器,则+1。
如果是HTML内样式,那么特殊性最优先,a=1
id选择器的特殊性是b,
类选择器、伪类选择器、属性选择器为c
标签选择器、伪元素选择器为d
先来说说一些选择器类型:
1.id选择器

  1. #myid { ... }  

2.类选择器

  1. .myclass { ... }  

3.标签选择器

  1. p { ... }  

4.属性选择器

  1. [title="mytitle"] { ... }  

由于大多数文档例如W3CSCHOOL可能并没有详细说明,或许不少人认为属性选择器是这样的  div[title="mytitle"] 或#id[title="mytitle"]等等,这样是属性选择器,严格来说,这样的并非单纯的属性选择器,而是由id选择器、标签选择器等等和属性选择共同组成的。
5.伪类选择器

  1. p:hover { ... }  

常见的伪类选择器有:
链接伪类,:link, :visited,用于锚元素。
动态伪类,:hover,:focus,:active,用于任何选择。
6.伪元素选择器

  1. p::after { ... }   
  2. p::before { ... }  

伪元素和伪类是完全不同的概念,之所以称之为伪元素,因为其确实可以生成一个虚拟的HTML元素,只不过伪元素无法被DOM获取到。
伪元素的应用有很多,最常见的比如::after清除浮动:

  1. <ul>   
  2.     <li>A</li>   
  3.     <li>B</li>   
  4. </ul>   
  5. <style>   
  6.     li { float:left }   
  7.     ul::after { content: ""; display: block; clear: both }   
  8. </style>  

CSS特殊性示例
下面是一些CSS选择器的特殊性示例:

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

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

相关文章

  • 2017-08-06使用css3实现的windows8开机加载动画
  • 2017-08-06CSS的相邻兄弟选择器用法简单讲解
  • 2017-08-06绝对定位元素的水平垂直居中的方法(3种任选)
  • 2017-08-06CSS选择器的权重与优先规则分享
  • 2017-08-06DIV+CSS 布局代码精简对SEO的影响
  • 2017-08-06深入理解CSS定位与层叠
  • 2017-08-06获取元素位置的position()与offset()方法区别介绍
  • 2017-08-06css实现背景渐变与底部固定的蓝天白云示例
  • 2017-08-06浅谈css中图片定位之所有图标放在一张图上
  • 2017-08-06浏览器对于含小数值px(像素)解析的差异及小数值如何解决兼容性问题

文章分类

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

最近更新的内容

    • CSS display:inline和float:left两者区别探讨
    • input css常用属性
    • DIV 边距属性在Chrome和IE中的区别深入理解
    • 用css border实现尖三角的写法(无图片)
    • CSS padding属性定义边内补白
    • CSS实现的灰色下拉菜单效果代码
    • 30个你不可不知的CSS选择器小结
    • 纯HTML+CSS3制作导航菜单(附源码)
    • 实例教程 一款纯css3实现的数字统计游戏
    • IE6中的position:fixed定位兼容性写法分享

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

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

选择器 特殊性 以10为基数的特殊性
style="color: red" 1, 0, 0, 0 1000
#id {} 0, 1, 0, 0 100
#id #aid 0, 2, 0, 0 200
.sty {} 0, 0, 1, 0 10
.sty p[title=""] {} 0, 0, 2, 0 20
p:hover {} 0, 0, 1, 0 10
p {} 0, 0, 0, 1 1
ul::after {} 0, 0, 0, 1 1
div p {} 0, 0, 0, 2 2