快速业务通道

CSS:相同元素不同结构重复定义的问题

作者 佚名技术 来源 CSS技术 浏览 发布时间 2012-03-05

CSS选择器是构建CSS的基础.在为大型,复杂嵌套的(x)HTML文档进行样式定义时,很有可能会遇上针对相同元素在不同结构下的重复定义的问题,这个问题也是前端开发人员相对头痛的问题.

在这种情况 (针对相同元素在不同结构下的重复定义) 发生的前提下,浏览器在渲染页面文件时,会按照一定规则进行优先级排列,然后根据这个优先级权重对发生状况的元素进行处理.

而这个浏览器遵循的规则是什么呢?

让我们来看一段简单的HTML代码:

<body id="content">
        <div class="box">
                <p class="italic">For Testing 2</p>
                <em id="em" class="wrap">For Testing 3</em>
        </div>
</body>

 这是段相当简单的HTML代码,但是具有相当的代表性.我们慢慢就能发现它为什么具有代表性了.

首先我们来加上一点简单的CSS声明:

p{ /* 1 */
        color:pink;
}
p.italic{ /* 11 */
        color:red;
}
div.box p{ /* 12 */
        color:black;
}
div p{ /* 2 */
        color:blue;
}
#content div p{ /* 102 */
        color:orange;
}
div p.italic{ /* 12 */
        color:green;
}
body div p{ /* 3 */
       color:olive;
}
body div p.italic/* 13 */
        color:gray;
}

大家来猜猜看结果中的"For Testing2"是什么颜色的呢?嗯...不浪费大家眼神了,结果是orange的,奇怪吗?有疑问吗?大家有没有注意到我在CSS中加入的注释中的数字?这是什么呢?这是CSS选择器特性权重值.

id选择器,class类选择器,HTML标签选择器,这3种选择器就是构成CSS继承的组件,浏览器在渲染它们的时候是有优先权的.而这个优先权在一定情况下是可以计算出来的.

  1. 统计在

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号