css代码重用和覆盖问题

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>CSS覆盖TEST</title>
<style>
.b{background-color:green; color:#CCCCCC}
.a .b{background-color:blue}
#a {background-color:green;color:#CCCCCC}
#a #b {background-color:blue}
</style>
</head>
<body>
<div class="a">
<div class="b" style="background-color:red">测试1</div>
</div>
<div id="a">
<div id="b" style="background-color:red">测试2</div>
</div>
</body>
</html>

这段测试代码说明了.b{}影响.a .b{}中的文字颜色,但是没有影响背景颜色。
.b{绿},a .b{蓝}和div自己的style(红)都设置了背景颜色,但最后只显示红;
去掉style(红)之后编程蓝色;再去掉a .b{蓝}之后才变成绿色。
原因是同样的CSS会被覆盖。浏览器使用样式的顺序为.b{绿}—〉a .b{蓝}—〉style(红)而后面的样式把前面的样式覆盖掉了。而在class和id下效果是同样的。 :wink:
注:样式最好还是使用class编辑,id具有唯一性,也就是说一张网页不能有重复的id。虽然目前浏览器也支持重复id,但这样会影响js操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值