深入剖析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.mswzjz.cn/qtweb/news28/219828.html">深入剖析CSS层叠与继承的使用</a> <br> 文章转载:<a href="http://www.mswzjz.cn/qtweb/news28/219828.html">http://www.mswzjz.cn/qtweb/news28/219828.html</a> </p> <p> 攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等 </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.mswzjz.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/daohang/">网站导航知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news0/305200.html">C#FileSystemWatcher对象的实例</a> </li><li> <a class="text_overflow" href="/qtweb/news33/444283.html">快速更新Linux网卡驱动:完全指南(linux如何更新网卡驱动)</a> </li><li> <a class="text_overflow" href="/qtweb/news40/495590.html">苏州云服务器租用怎么收费</a> </li><li> <a class="text_overflow" href="/qtweb/news33/357483.html">Docker网络之单host网络的示例分析</a> </li><li> <a class="text_overflow" href="/qtweb/news22/395822.html">opporeno7怎么修改便签模式_opporeno7修改便签模式教程</a> </li><li> <a class="text_overflow" href="/qtweb/news21/8721.html">Linux 函数 atoi 的使用方法(linuxatoi)</a> </li><li> <a class="text_overflow" href="/qtweb/news17/220217.html">Linux下如何复制整个目录(linux 复制整个目录)</a> </li><li> <a class="text_overflow" href="/qtweb/news49/434799.html">Linux下使用cp脚本完美备份文件 (linux cp脚本)</a> </li><li> <a class="text_overflow" href="/qtweb/news5/327405.html">广电无线网怎么设置?(广电宽带怎么设置无线路由器,广电宽带如何设置路由器)</a> </li><li> <a class="text_overflow" href="/qtweb/news9/321659.html">虎口夺食:通信运营商做“云”有没有出路?</a> </li><li> <a class="text_overflow" href="/qtweb/news35/201185.html">按量计算什么意思?(按量收费服务器)</a> </li><li> <a class="text_overflow" href="/qtweb/news7/106657.html">Linux无需Virtalbox:实现灵活的计算空间(linux没有vg)</a> </li><li> <a class="text_overflow" href="/qtweb/news27/148977.html">Seo优化关键词怎么部署?</a> </li><li> <a class="text_overflow" href="/qtweb/news2/485252.html">数据库备份加星号:保护你的数据安全。(数据库文件备份出来带星号)</a> </li><li> <a class="text_overflow" href="/qtweb/news15/82015.html">win8替换文件需要管理员权限?windows8权限</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/led/" target="_blank">LED显示屏</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/mbzx/" 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/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/suliaodai/" 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/jszz/" 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/tongdiaosu/" 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/ggzz/" 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/blgds/" 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/bolimo/" 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/shayanfudiao/" 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/vr/" target="_blank">VR全景</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/yangguangfang/" 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/qchs/" 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/cantingsj/" target="_blank">餐厅设计</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="https://www.cdcxhl.com/idc/cqstsanx.html" target="_blank">重庆水土三线托管</a>    <a href="http://www.cdxwcx.cn/tuoguan/deyang.html" target="_blank">德阳服务器托管</a>    <a href="http://www.cdwuji.cn/" target="_blank">成都网站建设</a>    <a href="http://www.szjierui.cn/" target="_blank">主动防护网</a>    <a href="https://www.cdxwcx.com/wangzhan/mbshangcheng.html" target="_blank">电子商务商城网站</a>    <a href="https://www.cdxwcx.com/city/mianzhu/" target="_blank">绵竹做网站</a>    <a href="http://chengdu.cdcxhl.com/seo/" target="_blank">成都网站排名</a>    <a href="https://www.cdcxhl.com/weihu/chengdu.html" target="_blank">成都网站维护公司</a>    <a href="https://www.cdcxhl.com/tuoguan/ershu/" target="_blank">成都二枢机房</a>    <a href="http://www.4006tel.net/" target="_blank">app开发公司</a>    <a href="http://m.cdcxhl.cn/H5/" target="_blank">成都响应式网站建设</a>    <a href="http://www.emts.com.cn/about/" target="_blank">德阳东方电机技改服务有限公司</a>    <a href="http://seo.cdkjz.cn/mobile/" target="_blank">成都网站推广公司</a>    <a href="https://www.cdxwcx.com/city/meishan/" target="_blank">眉山做网站</a>    <a href="http://www.75109.cn/" target="_blank">精灵网</a>    <a href="http://www.tjysf.cn/" target="_blank">郫县明安消防器材</a>    <a href="http://www.cdymzj.com/" target="_blank">云主机</a>    <a href="https://www.cdcxhl.com/douyin/" target="_blank">短视频拍摄</a>    <a href="http://www.zgyiwo.cn/" target="_blank">普特斯腐植酸</a>    <a href="http://www.sichuanairmedia.com/" 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'"> 立即开始600网站建设</button> <button type="button" class="btn btn-default btn-xs" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 600网站制作</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.mswzjz.cn/" target="_blank">攀枝花网站设计</a> <a href="http://www.mswzjz.cn/" target="_blank">攀枝花网站制作</a> <a href="http://www.mswzjz.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>