子代选择器 子代自身冲突

先看一段简单的html代码:

<html><head><title>test</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
div p
{
color
:red;}

.son
{
color
:blue;}
</style>
</head>
<body>
<div class="father">
<p>TEST</p>
<p class="son">测试文字</p>
</div>
</body></html>

执行后内容的颜色分别是什么?

 

现在再来看一段代码,下面这段代码就是把div p样式改成了.father p,代码如下

<html><head><title>test</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
.father p
{
color
:red;}

.son
{
color
:blue;}
</style>
</head>
<body>
<div class="father">
<p>TEST</p>
<p class="son">测试文字</p>
</div>
</body></html>

执行后内容的颜色又分别是什么?

如果我们在这把上面div里面的class换成id,代码如下:

<html><head><title>test</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
#father p
{
color
:red;}

.son
{
color
:blue;}
</style>
</head>
<body>
<div id="father">
<p>TEST</p>
<p class="son">测试文字</p>
</div>
</body></html>

执行后内容的颜色又分别是什么? 

小结:以上变化可以看出“测试文字”的颜色变化不是由于它最近的son样式决定,也不是由子选择器决定,是由两者共同决定的,其实还可以有变化,就是测试子选择器里面的p换成p里面的class,div用id或者div进行变化;

css优先级规则:行内样式>id样式>类别样式>标记样式

变化规则我总结下基本上是:如果子选择器(即上面第一个样式“红色”那个)两部分 (父 子)中父或者子“任意一个”用的是高于测试文字最近的直接选择(即上面的第二个样式),那么测试文字都是由子选择器(第一个样式)决定,否则就是由第二个。

转载于:https://www.cnblogs.com/sh7ning/archive/2012/04/07/2436015.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值