css中有很多选择器,比如类选择器,标签选择器,id选择器等等,不同选择器之间的优先级顺序也不一样,今天就和大家聊聊css选择器的优先级顺序,以及、!important的使用,有需要的朋友可以参考一下,希望对你有用。
1、!important 表示最高优先级。ie6浏览器不认识 !important 。
举例:
正常情况下,写在下面的样式优先级高于上面的样式
demo1{color:red;color:green; /*绿色的优先级高于红色,所有浏览器都会显示绿色*/}
加了!important 那么它的优先级会比较高,ie6比较傻,不认识。
立即学习“前端免费学习笔记(深入)”;
demo2 {color:red !important; /*除了ie6,其他浏览器会认为红色优先级高,显示红色字体*/color:green; /*ie6浏览器则顺序读取css所以显示绿色*/}
但是注意,ie6不认识!important的优先级,但并不代表ie6不认识带!important的样式属性。
demo3{color:red;color:green !important; /*包括ie6,所有浏览器都显示绿色字体,ie6只是不认识优先级罢了*/}
2、CSS (Cascading Style Sheets) 级联样式表,在实际应用中,一般有以下三种级联方式。
优先级:内联样式表(标签内部)> 嵌入样式表(当前文件中)> 外部样式表(外部文件中)。
1. 外联式(应用于多个网页)
外联式样式表中,CSS 代码作为文件单独存放,如以 style.css 文件包含所有样式。在 HTML 中的外部级联采用 标记或者 @import 语句来引入。
示例代码如下:
//link 链接@import url("style.css"); //@import 导入
和 @import 的异同见其文章
2. 内联式(应用于当前页面)
门户网站的 CSS 代码通常采用嵌入式,即通常所说的内联方式 (Inline Style),其使用 标记将样式定义为内部块对象。
示例代码如下:
body{font-family:Arial,Helvetica,sans-serif;}
内联 CSS 可以有效减少 HTTP 请求,提升页面性能,缓解服务器压力。由于浏览器加载完 CSS 才能渲染页面,因此能防止 CSS 文件无法读取而造成页面裸奔的现象。
3. 嵌入式(应用于具体的标签)
最初级的 CSS 写法即把代码直接添加于所修饰的标记元素。
示例代码如下:
饿了么
这样做虽然更为直观,但很大程度上加大了页面体积,不符合结构与表现分离的设计思想。
3、权值不同时,浏览器是根据权值来判断使用哪种选择器的css样式,样式权值高的就使用哪种样式。
权值规则:标签(P、span)的权值为1,类选择器的权值为10,id选择器的权值最高为100。
举例:
div {color: red;} /*标签,权值为1*/
div span {color: green;} /*两个标签,权值为1+1=2*/
div>span {color: purple;} /*权值与上面的相同,因此采取就近原则*/
.main {color: white;} /*类选择符,权值为10*/
div span.warning {color: purple;} /*权值为1+1+10=12*/
#main .con p {color: yellow;} /*权值为100+10+1=111*/
以上就是深入理解CSS选择器的优先级顺序的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1611938.html
微信扫一扫
支付宝扫一扫