css样式覆盖顺序_html/css_WEB-ITnose

php中文网
发布: 2016-06-24 11:25:46
原创
1245人浏览过

0.样式位置分类

1)使用外部css文件

<link href="/static/css/main.css" rel="stylesheet">
登录后复制

2)使用head中的style元素

<head><style type="text/css">    .main{color:red;}</style></head>
登录后复制

3)使用元素上的style

<body style="color:red;"></body>
登录后复制

 

1.样式覆盖总体原则:

壁纸样机神器
壁纸样机神器

免费壁纸样机生成

壁纸样机神器 0
查看详情 壁纸样机神器

元素上的style > 文件头上的style元素 >外部样式文件

不同级别的样式均对同一元素进行渲染时,对于冲突的样式,会优先采取元素上的style去覆盖文件头上的style元素;对于不冲突的样式,会进行样式叠加。

例如:

<head><style type="text/css">    .main{color:red;background-color:yellow;}</style></head><body id="mainbody" class="main" style="color:green;"></body>
登录后复制

对于body元素,元素style与文件头上的style均会命中,此时,backgroud-color样式会进行叠加,color样式出现冲突,会优先选用body元素中的样式。渲染结果为:

color:green;background-color:yellow;
登录后复制

 

2.同级别样式文件下:

1)样式表的元素选择器选择越精确,样式优先级越高:

id选择器指定的样式 > 类选择器指定的样式 > 元素类型选择器指定的样式

在示例中,css进行渲染时,#mainbody > .main > body

 

2)对于相同类型选择器制定的样式,在样式表文件中,越靠后的优先级越高:

这里是样式表文件中越靠后的优先级越高,而不是在元素class出现的顺序。

 

例如,.class2 在样式表中出现在.class1之后,

.class1{    color:red;}.class2{    color:green;}
登录后复制

对于

<div class="class2 class1"><div class="class1 class2">
登录后复制

虽然class1在元素中指定时排在class2的后面,但因为在样式表文件中class1处于class2前面,此时仍然是class2的优先级更高,将采用 color:green 

 

3)如果要让某个样式的优先级变高,可以使用!important

<head><style type="text/css">    .main{color:red !important; background-color:yellow;}</style></head><body id="mainbody" class="main" style="color:green;"></body>
登录后复制

由于head的style中使用了 !important ,渲染时将会采用 color:red 

 

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号