深入剖析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.shufengxianlan.com/qtweb/news28/219828.html">深入剖析CSS层叠与继承的使用</a> <br> 网站网址:<a href="http://www.shufengxianlan.com/qtweb/news28/219828.html">http://www.shufengxianlan.com/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="https://www.cdcxhl.com/" 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/mobile/">手机网站建设知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news41/197391.html">批处理ifelse用法?windows批处理ifelse</a> </li><li> <a class="text_overflow" href="/qtweb/news17/369217.html">卡盟如何登录页面</a> </li><li> <a class="text_overflow" href="/qtweb/news0/201250.html">为什么我的XP系统的窗口可以变成透明?windowsxp任务栏透明</a> </li><li> <a class="text_overflow" href="/qtweb/news4/109804.html">创新互联小程序教程:微信小程序运力方使用·onAgentPosQuery</a> </li><li> <a class="text_overflow" href="/qtweb/news9/295359.html">用c语言编写分段函数(分段函数的反函数怎么写)</a> </li><li> <a class="text_overflow" href="/qtweb/news40/53190.html">硬盘录像机虚拟主机是什么意思?(虚拟主机管理系统)</a> </li><li> <a class="text_overflow" href="/qtweb/news20/325520.html">Redis管理高效的运维框架(redis运维框架)</a> </li><li> <a class="text_overflow" href="/qtweb/news47/444897.html">app备案规定?内网服务器需要备案不</a> </li><li> <a class="text_overflow" href="/qtweb/news12/447212.html">前端代码如何部署到云服务器?(如何将一个软件部署到云服务器)</a> </li><li> <a class="text_overflow" href="/qtweb/news34/548734.html">虚拟主机拦截设置的方法是什么</a> </li><li> <a class="text_overflow" href="/qtweb/news3/234703.html">突破Redis让应用技术更上一层楼(redis的几种应用技术)</a> </li><li> <a class="text_overflow" href="/qtweb/news35/56735.html">如何连接数据库服务器名称?(链接数据库服务器名称)</a> </li><li> <a class="text_overflow" href="/qtweb/news22/272222.html">linux查看当前的网络配置?(linux怎么查看网络状态)</a> </li><li> <a class="text_overflow" href="/qtweb/news45/109745.html">如何修复Windows11/10上的ntdll.dll崩溃问题</a> </li><li> <a class="text_overflow" href="/qtweb/news38/530988.html">基于Java的Redis实现云存储(redis结合java)</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/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/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/boligeduan/" 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/zsljbc/" 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/bangongkongjian/" 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/iso/" target="_blank">iso认证</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/ldjbc/" 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/fadianji/" 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/tadiaozulin/" 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/shachuang/" 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/sdjbc/" 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/bgcl/" 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/lajitong/" 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/chalousj/" target="_blank">茶楼设计</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="http://www.2518874.com/" target="_blank">王君美油画</a>    <a href="https://www.cdcxhl.com/idc/yidong.html" target="_blank">成都移动机房</a>    <a href="https://www.cdcxhl.com/ssl/chengdu.html" target="_blank">ssl数字证书</a>    <a href="http://m.cdxwcx.com/xibuxinxi.html" target="_blank">西部信息服务器托管</a>    <a href="http://www.cdhuace.com/faguangzi/wbfgz.html" target="_blank">led无边发光字</a>    <a href="http://www.cxjianzhan.com/seo/" target="_blank">成都网络营销</a>    <a href="http://chengdu.cdcxhl.cn/wechat/ " target="_blank">成都微信开发</a>    <a href="http://chengdu.cdcxhl.cn/dingzhi/" target="_blank">成都定制网站建设</a>    <a href="https://www.cdcxhl.com/hangyead/" target="_blank">一元广告</a>    <a href="http://www.cdkjz.cn/fangan/led/" target="_blank">LED网站设计方案</a>    <a href="http://chengdu.cdcxhl.com/weixin/" target="_blank">微信公众号开发</a>    <a href="http://m.cdcxhl.com/" target="_blank">成都网站制作</a>    <a href="http://www.cdfuwuqi.com/cloud/" target="_blank">云服务器</a>    <a href="http://m.cdcxhl.cn/dingzhi/ " target="_blank">高端定制网站建设</a>    <a href="http://www.myzwz.com/" target="_blank">绵阳网站建设</a>    <a href="http://www.shruijie.cn/" target="_blank">上海除甲醛</a>    <a href="http://m.cdcxhl.cn/seo/ " target="_blank">成都网站建设</a>    <a href="http://m.cdxwcx.com/zuo.html" target="_blank">做网站的公司</a>    <a href="https://www.cdxwcx.com/wangzhan/dingzhi.html" target="_blank">定制网站</a>    <a href="http://www.cdxwcx.cn/tuoguan/zuyong.html" 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="https://www.cdcxhl.com/" target="_blank">网站设计</a> <a href="https://www.cdcxhl.com/" target="_blank">网站制作</a> <a href="https://www.cdcxhl.com/" 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:400-028-6601(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>