深入剖析CSS层叠与继承的使用

你对CSS层叠和继承的概念和用法你是否熟悉,这里和大家分享一下,文档中的一个元素可能同时被多个CSS选择器选中,每个选择器都有一些CSS规则,这就是层叠,而所谓继承,就是父元素的规则也会适用于子元素。

创新互联成立十载来,这条路我们正越走越好,积累了技术与客户资源,形成了良好的口碑。为客户提供成都做网站、网站建设、网站策划、网页设计、域名注册、网络营销、VI设计、网站改版、漏洞修补等服务。网站是否美观、功能强大、用户体验好、性价比高、打开快等等,这些对于网站建设都非常重要,创新互联通过对建站技术性的掌握、对创意设计的研究为客户提供一站式互联网解决方案,携手广大客户,共同发展进步。

CSS技术理论:CSS层叠与继承

一、CSS层叠

我们知道文档中的一个元素可能同时被多个CSS选择器选中,每个选择器都有一些CSS规则,这就是CSS层叠。这些规则有可能不矛盾的,自然这些规则将会同时起效,然而有些规则是相互冲突的,例如:

 Example Source Code

 
 
 
  1.  
  2.  
  3.     CSS Cascade title> </li> <li>    <style type="text/CSS"> </li> <li>    h1{color:Red;}  </li> <li>    body h1{color:Blue;}  </li> <li>     style> </li> <li> head> </li> <li><body> </li> <li><h1>Hello 52CSS.com h1> </li> <li> body> </li> <li> html> </li> <li> </li> </ol></pre><p>   为此需要为每条规则制定特殊性,当发生冲突的时候必须选出一条***特殊性的规则来应用。CSS规则的特殊性可以用4个整数来表示,例如0,0,0,0.计算规则如下:</p><p>◆对于规则中的每个ID选择符,特殊性加0,1,0,0</p><p>◆对于规则中每个类选择符和属性选择符以及伪类,特殊性加0,0,1,0</p><p>◆对于规则中的每个元素名或者伪元素,特殊性加0,0,0,1</p><p>◆对于通配符,特殊性加0,0,0,0.</p><p>◆对于内联规则,特殊性加 1,0,0,0</p><p>最终得到结果就是这个规则的特殊性。两个特殊性的比较类似字符串大小的比较,是从左往右依次比较,***个数字大的规则的特殊性高。上例中两条规则的特殊性分别是0,0,0,1 和 0,0,0,2,显然第二条胜出,因此最终字是蓝色的。<br />  注意,通配符的特殊性0,0,0,0看起来没有作用,实际上不是,还有一种没有特殊性的规则,0,0,0,0要比没有特殊性更特殊,下面会介绍。</p><p>CSS还有一个!important标签,用来改变CSS规则的特殊性。实际上,在解析CSS规则特殊性的时候,是将具有!important的规则和没有此标签的规则利用上述方法分别计算特殊性,分别选出特殊性***的规则。最终合并的时候,具有任何特殊性的带有!important标记的规则胜出。#p#</p><p><strong>二、CSS继承</strong></p><p>所谓CSS继承,就是父元素的规则也会适用于子元素。比如给body设置为color:Red;那么他内部的元素如果没有其他的规则设置,也都会变成红色。CSS继承得来的规则没有特殊性。下面看一个简单的例子:</p><p> Example Source Code</p><pre> <ol> <li><html xmlns="http://www.w3.org/1999/xhtml"> </li> <li><head> </li> <li>    <title>CSS Cascade title> </li> <li>    <style type="text/CSS">   </li> <li>     *{color:Blue;}  </li> <li>     div{color:Black;}  </li> <li>     .imp{color:Red !important;}  </li> <li>     #content{color:Green;}     </li> <li>     style> </li> <li> head> </li> <li><body> </li> <li> <div>Hello <span>52CSS.com span>  div> </li> <li> <div id="content"> </li> <li>    <p class="imp">Title p> </li> <li>    Content Goes Here.  </li> <li>  div> </li> <li> body> </li> <li> html>   </li> </ol></pre><p>注意,***行的CSS并没有继承div的黑色,这是因为通配符的缘故。通配符的特殊性虽然是全0,但是还是比继承的特殊性要高。第二行展示了!important标记的作用。<br />  另外,一些明显不应该继承的属性,比如border,margin,padding之类的是不会被CSS继承的,具体可以参考CSS手册。</p><p><strong>三、其他</strong></p><p>虽然有4个整数来表示一个特殊性,仍然有可能出现两条冲突的规则的特殊性完全一致的情况,此时就按照CSS规则出现的顺序来确定,在样式表中***一个出现的规则胜出。一般不会出现这样的情况,只有一个情况例外,考虑如下样式表:</p><p> Example Source Code</p><pre> <ol> <li>:active{color:Red;}  </li> <li>:hover{color:Blue;}  </li> <li>:visited{color:Purple;}  </li> <li>:link{color:Green;}      </li> <li> </li> </ol></pre><p>这样页面中的链接永远也不会显示红色和蓝色,因为一个链接要么被访问过,要么没有被访问过。而这两条规则在***,因此总会胜出。如果改成这样:</p><p> Example Source Code</p><pre> <ol> <li>:link{color:Green;}    </li> <li>:visited{color:Purple;}  </li> <li>:hover{color:Blue;}  </li> <li>:active{color:Red;}  </li> <li> </li> </ol></pre><p>就能实现鼠标悬停和点击的瞬间变色的效果。这样的顺序的首字母正好连成 “LoVe HA”,这样的顺序被约定俗成的叫做Love Ha 规则。特殊性规则从理论上讲比较抽象和难懂,但在实践中,只要样式表是设计良好的,并不会有太多这方面的困扰,因此本文也不再做深究,更多的技术请参考的文章更新!<br /></p><p>【编辑推荐】</p><ol><li>CSS层叠与继承用法手册</li><li>解析Flex中CSS层叠样式表的应用方法</li><li>全面解析CSS优先级规则</li><li>专家推荐 10款优秀CSS框架</li><li>实例解析清除CSS float浮动的三种方法</li></ol> <p> 本文标题:<a href="http://www.csdahua.cn/qtweb/news28/219828.html">深入剖析CSS层叠与继承的使用</a> <br> 网站地址:<a href="http://www.csdahua.cn/qtweb/news28/219828.html">http://www.csdahua.cn/qtweb/news28/219828.html</a> </p> <p> 网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等 </p> <p class="adpic"> <a href="https://www.cdcxhl.com/service/ad.html" target="_blank" class="ad">广告</a> <a href="" target="_blank" class="adimg"><img src=""></a> </p> <p class="copy"> 声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: <a href="http://www.csdahua.cn/" target="_blank">快上网</a> </p> </div> <div class="newsmorelb"> <p>成都快上网为您推荐相关内容</p> <ul> <li> <a href="/qtweb/news27/219827.html">数据库不见了怎么处理?(我吴删了数据库你们这边能帮我还原下之前的数据码)</a> </li><li> <a href="/qtweb/news26/219826.html">惠普服务器热备盘怎么做</a> </li><li> <a href="/qtweb/news25/219825.html">Linux下使用JQ快速管理JSON数据(linuxjq)</a> </li><li> <a href="/qtweb/news24/219824.html">好评如潮的便宜vPS主机,让你轻松享受高性能虚拟私有服务器</a> </li><li> <a href="/qtweb/news23/219823.html">Linux文件夹恢复:快速找回误删除的数据(linux文件恢复文件夹)</a> </li><li> <a href="/qtweb/news22/219822.html">怎样查询一个网站的域名服务商?(怎么看网站域名拥有商品数量)</a> </li><li> <a href="/qtweb/news21/219821.html">windows10驱动修复?(windows10驱动修复后无法开机)</a> </li><li> <a href="/qtweb/news20/219820.html">揭穿三大云原生安全误区</a> </li><li> <a href="/qtweb/news19/219819.html">香港云服务器延时高怎么办</a> </li> </ul> </div> </div> <div class="col-lg-3 noneb"> <div class="bkright" style="margin-top: 0"> <p><a href="https://www.cdcxhl.com/news/waimaojianshe/">外贸网站建设知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news15/57815.html">美国实惠vps</a> </li><li> <a class="text_overflow" href="/qtweb/news4/234954.html">抖音为什么有缓存</a> </li><li> <a class="text_overflow" href="/qtweb/news48/408548.html">windows服务器的安装配置和维护?服务器系统重装数据</a> </li><li> <a class="text_overflow" href="/qtweb/news36/328136.html">揭秘Linux开机过程:从引导开始的启动过程(linux开机过程)</a> </li><li> <a class="text_overflow" href="/qtweb/news30/56480.html">WPS用什么登录电脑不留痕迹</a> </li><li> <a class="text_overflow" href="/qtweb/news18/341618.html">施耐德电气:数字化,让能源管理更加“主动”</a> </li><li> <a class="text_overflow" href="/qtweb/news28/153428.html">windows是哪个公司发明的?windows自造字</a> </li><li> <a class="text_overflow" href="/qtweb/news19/283769.html">PHP书写规范</a> </li><li> <a class="text_overflow" href="/qtweb/news12/515162.html">创新互联Python教程:sublime运行python提示错误解决方法</a> </li><li> <a class="text_overflow" href="/qtweb/news42/155642.html">IIS入门:为智能城市应用设置IIS</a> </li><li> <a class="text_overflow" href="/qtweb/news8/480308.html">Oracle数据库性能模型</a> </li><li> <a class="text_overflow" href="/qtweb/news35/64635.html">代码详解:使用JavaScript进行面向对象编程的指南</a> </li><li> <a class="text_overflow" href="/qtweb/news1/190801.html">s.split函数python</a> </li><li> <a class="text_overflow" href="/qtweb/news19/28569.html">美国服务器怎么做防御</a> </li><li> <a class="text_overflow" href="/qtweb/news6/32506.html">云服务器怎么理解?(云服务器怎么理解文件)</a> </li> </ul> </div> <div class="bkright tag"> <p><a href="https://www.cdcxhl.com/hangye/" target="_blank">行业网站建设</a></p> <ul> <li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sljbc/" target="_blank">生料搅拌车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/menchuang/" target="_blank">门窗定制</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/gangting/" target="_blank">岗亭</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/weixiufdj/" target="_blank">发电机维修</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shipindai/" target="_blank">食品包装袋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/fwqtg/" target="_blank">服务器托管</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bdfhw/" target="_blank">被动防护网</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zdfhw/" target="_blank">主动防护网</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sdgz/" target="_blank">水电改造</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/pvc/" target="_blank">PVC花箱</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/ggsj/" target="_blank">广告设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/chayisj/" target="_blank">茶艺设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bpfhw/" target="_blank">边坡防护网</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/xuanchuanpian/" target="_blank">宣传片制作</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sqwhq/" target="_blank">社区文化墙</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zhixiang/" target="_blank">纸箱</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="http://www.lzhejiang.com/" target="_blank">合江网站建设</a>    <a href="https://www.cdcxhl.com/shoulu/" target="_blank">网站快速收录</a>    <a href="http://www.hzxinyuan.com/" target="_blank">佑馨产后护理</a>    <a href="https://www.cdcxhl.com/quanwang.html" target="_blank">全网整合营销推广</a>    <a href="http://www.cxjianzhan.com/" target="_blank">网站推广</a>    <a href="https://www.cdcxhl.cn/ " target="_blank">云虚拟主机</a>    <a href="https://www.cdcxhl.cn/ " target="_blank">腾讯云香港空间</a>    <a href="http://www.cdwuji.cn/" target="_blank">成都网站建设</a>    <a href="http://seo.cdcxhl.cn/wztg/" target="_blank">成都外贸网站优化</a>    <a href="https://www.cdxwcx.com/jifang/meishan.html" target="_blank">眉山联通机房</a>    <a href="https://www.cdxwcx.com/jifang/xiyun.html" target="_blank">西云机房</a>    <a href="https://www.cdxwcx.com/jifang/xiyun.html" target="_blank">移动服务器托管</a>    <a href="http://www.cdsjymy.cn/" target="_blank">路面机械及配件</a>    <a href="http://www.gswzjz.com/" target="_blank">工商财税</a>    <a href="https://www.cdcxhl.com/quanwang.html" target="_blank">全网营销推广</a>    <a href="https://www.cdcxhl.cn/ " target="_blank">腾讯香港虚拟主机</a>    <a href="http://m.xwcx.net/wechat/" target="_blank">成都微信二次开发</a>    <a href="https://www.cdxwcx.com/wangzhan/mbyidong.html" target="_blank">wap手机网站</a>    <a href="https://www.cdxwcx.com/jifang/xibuxinxi.html" target="_blank">西部信息服务器托管</a>    <a href="http://www.idckuai.cn/" target="_blank">域名注册</a>     </div> </div> <footer> <div class="carousel-inner footjz"> <div class="container"> <i class="icon iconfont zbw"></i> 高品质定制 <i class="icon iconfont"></i> 跨终端自动兼容 <i class="icon iconfont"></i> 节约开发成本 <i class="icon iconfont"></i> 开发周期短 <i class="icon iconfont"></i> 一体化服务 <button type="button" class="btn btn-default btn-lg" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 立即开始2800定制网站建设</button> <button type="button" class="btn btn-default btn-xs" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 2800定制网站建设</button> </div> </div> <div class="carousel-inner bqsy"> <div class="container"> <div class="lxfs"> <h4 class="yutelnone">028-86922220 13518219792</h4> <h4 class="yutelblock"><a href="tel:02886922220">028-86922220</a> <a href="tel:13518219792">13518219792</a></h4> <a class="btn btn-default" href="tencent://message/?uin=532337155&Site=&Menu=yes" role="button">网站建设<span>QQ</span>:532337155</a> <a class="btn btn-default" href="tencent://message/?uin=631063699&Site=&Menu=yes" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=532337155&version=1&src_type=web&web_src=oicqzone.com" role="button">网站制作<span>QQ</span>:532337155</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=631063699&version=1&src_type=web&web_src=oicqzone.com" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn-default nonea" href="tencent://message/?uin=1683211881&Site=&Menu=yes" role="button">售后QQ:1683211881</a> <div class="dz">成都快上网专注: <a href="http://www.csdahua.cn/" target="_blank">网站优化</a> <a href="http://www.csdahua.cn/" target="_blank">网络推广</a> <a href="http://www.csdahua.cn/" target="_blank">网站建设</a> <address>地址:成都太升南路288号锦天国际A幢10楼</address> </div> </div> <div class="bzdh dz"><img src="https://www.cdcxhl.com/imges/bottom_logo.png" alt="创新互联"> <p><a href="https://www.cdcxhl.com/menu.html" target="_blank">成都创新互联科技有限公司</a><br> Tel:028-86922220(7x24h)</p></div> </div> </div> </footer> </body> </html> <script> $.getJSON ("../../qtwebpic.txt", function (data) { var jsonContent = { "featured":data } var random = jsonContent.featured[Math.floor(Math.random() * jsonContent.featured.length)]; $(".adpic .adimg").attr("href",random.link) $(".adpic img").attr("src",random.pic); }) </script>