首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

网页 CSS继承性

欢迎点击「算法与编程之美」关注我们!

本文首发于微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章。

提出问题

为了使我们的网页能够以更加有效的方式设置为网页格式,我们添加CSS,但我们不可能重复的添加相同的样式,这样太浪费时间,因此CSS增加了继承。继承是指包含在内部样式的标签能够拥有外部标签的样式性,即子元素可以继承父元素的属性。这种继承性允许样式不仅应用于某个特定的元素,同时也应用于其后代,而其后代所定义的新样式,却不会影响父代样式。但我们在写写继承的时候总是会出错,所以接下来我们就来系统的讲一下CSS的继承性的一些特殊点。

解决问题

1、CSS继承的局限性

在CSS中,继承是一种非常自然的行为,我们甚至不需要考虑是否能够这样去做,但是继续也有其局限性。首先,有些属性是不可继承的。这没有任何原因,只是因为它就是这么设置的。举个例子来说:border属性,大家都知道,border属性是用来设置元素的边框的,它就没有继承性。如果继承了边框属性,那么文档看起来就会很奇怪,除非采取另外的办法闭掉边框的继承属性。Padding(补白),Margin(边界),背景和边框的属性都是不能继承的。

2.继承中容易引起的错误

有时候继承也会带来些错误,比如说下面这条CSS定义:

在有些浏览器中这句定义会使除表格之外的文本变成蓝色。从技术上来说,这是不正确的,但是它确实存在。所以我们经常需要借助于某些技巧,比如将CSS定义成这样:

这样表格内的文字也会变成蓝色

3.多种样式混合应用

既然有了继承性,那么在样式表中的应用上可能会有些读者搞不清,多个样式表同时应用到一个对象上会发生什么情形呢?先举个简单的例子:

样式定义:

应用举例代码:

应用举例效果:

因为选择符H1和.apple都匹配上面的H1元素,那么到底浏览器会应用哪一个呢?通过在浏览器中观察,我们发现这段文字应用了.apple这个样式,所以它显示的是红色。这是因为两条规则的特殊性不一样,CSS规则必须这样进行处理。

样式表中的特殊性描述了不同规则的相对权重,它的基本规则是:

1)统计选择符中的ID属性个数。

2)统计选择符中的CLASS属性个数。

3)统计选择符中的HTML标记名格式。

4.CSS继承的优先级问题

上面我们讨论了CSS的继承性和特殊性,在特殊性的框架下,被继承的特性值为0,这就意味着任何显示声明的规则将会覆盖其继承样式。因此,不管一条规则具有多高的权重,如果没有其他规则能应用于这个继承元素,那么它也只是个被继承的规则而已,举例说明。

样式定义:

应用举例代码:

结果:

为什么我们在ul里面设置了颜色为白色,但是显示出来的颜色却变成了灰色呢?因为带选择符li的显式声明的权值比从ul white规则那里继承过来的权值要大,所以每个列表项都是灰色的。所以在设置的时候要注意一下选择符的优先级。

CSS的继承是我们在写CSS样式时最容易出现的错误,我们要注意以上的一些内容,避免自己的样式显示不出来,又找不到问题。

END

实习编辑 | 王楠岚

责 编 | 杨金月

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20191106A004TN00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券