CSS控制继承有哪些通用属性值,怎样开启继承
Admin 2022-11-01 群英技术资讯 328 次浏览
我们知道,CSS 属性有可继承和不可继承之分,例如 height 和 width 就 是CSS 中典型的不可继承属性,color 和 font-size 是典型的可继承属性。CSS 可继承属性意味着后代元素的样式会继承祖先元素样式,例如一个父元素的 color 是 red,那么如果它的子孙元素自己没有设置 color 值,就会取自父元素的 color 值。同样的条件,CSS 属性由 color 改为 height,由于默认是不可继承属性,其子孙元素不会继承父元素的 height 值。
这就是 CSS 中的继承与非继承属性的区别,区别在于某一元素的某类样式值,会不会被其子孙元素继承,也就是其子孙元素的样式值会不会取自父元素。
css 中有三个概念对于理解 CSS 是如何工作的十分重要,他们分别是“层叠”、“优先级”和“继承”。
Mozilla 上关于 CSS 继承概念的解释: 在 CSS 中,每个 CSS 属性定义的概述都指出了这个属性是默认继承的("Inherited: Yes") 还是默认不继承的("Inherited: no")。这决定了当你没有为元素的属性指定值时该如何计算值。
CSS 为控制继承提供了四个特殊的通用属性值。每个css属性都接收这些值。 这意味着,就像 css 盒子模型可以通过改变 box-sizing 的值 (border-box 和 content-box)来改变。 css 属性的继承情况也是可以控制的,例如通过设置值 inherit、initial、unset 和 revert 来控制。
height 在 CSS 原生上不可继承属性,子元素不会继承父元素的 height, 但是这种现状是可以改变的,当子孙元素的 height 设置 为 inherit, 该子孙元素就会的 height 值就会取其父元素的 height 值,就像是子元素继承了父元素的高度。
如果你希望子元素的高度一直保持和父元素一直,那么设置子元素的 height 为 inherit,最合适不过了。
inherit:设置该属性会使子元素属性和父元素相同。实际上,就是 "开启继承"。这个值可以被几乎 CSS 所有属性 使用,也就是 width 等其他属性也可以开启继承。
下面是一个给子元素的 height 开启继承的示例:
<div> <p>这是一个普通的段落</p> </div>
div{ height: 200px; color: red; border: 1px solid red; font-size: 25px; } p{ border: 1px solid #1e87f0; height: inherit; /*开启继承后,自动继承了父元素的高度*/ margin: 0; }
all 结合 unset,重置几乎所有样式,这也可以看成是一种对原始继承的控制改变, all 属性,将这种改变的有效范围放大了,因为 unset 几乎可以重置所有属性的值。 这里的重置通常是指将属性重置为自然值,也就是如果属性是自然继承那么就是 inherit,否则和 initial一样。
CSS 的 shorthand 属性 all 可以用于同时将这些继承值中的一个,应用于(几乎)所有属性。 它的值可以是其中任意一个(inherit, initial, unset, or revert)。 这是一种撤销对样式所做更改的简便方法,以便回到之前已知的起点。
例如像下面这样:例子中有两个 div,第一个 div 应用了样式选择器 div 的样式, 第二个通过 类选择器 unset-all 设置 all 为 unset,重置了几乎所有样式。 例如 color、background-color 和 border 都被重置为浏览器默认样式了,原本两个段落的样式应该是一致的。
<div> <p>这是一段文字</p> </div> <div class="unset-all"> <p>这是另一段文字,它将被充值样式</p> </div>
div { color: red; background-color: red; border: 2px solid green; } .unset-all { all: unset; }
下面是一张测试样式重置的效果图:
所以,通过将子元素的 height 值设置 inherit,可以继承父元素的高度,这会使得子元素的高度始终保持一致,这有时会很便利。 当然 width 等大多数属性都可以这样开启继承。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文主要介绍CSS实现自适应三栏布局的内容,三栏布局是常用的布局之一,本文实现的自适应三栏布局是两边定宽,中间block宽度自适应的效果,下文会给大家介绍两种类型实现方法,感兴趣的朋友可以了解看看。
这篇文章给大家分享的是有关flex布局以及缩放的内容,flex布局是比较实用的,但是对于flex布局比例计算,一些朋友不是很了解,对此这篇文章就给大家来详细的介绍,感兴趣的朋友可以参考一下,接下来一起跟随小编看看吧。
css怎样去除按钮之间的间距正常情况下,当我们设置了按钮之后,按钮之间会出现间距,示例如下:<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <meta name="
chrome最小字体限制的问题如何解决?一些朋友可能知道Chrome 默认最小字体是12px,这样的设计也是出于为了更好显示中文,但是这样的设计也有一个坏处,就是可能会出现某些上标、下标字体过大的情况,这对于用户体验并不好,那么我们有没有什么解决方法呢?接下来给大家分享两种方法,感兴趣的朋友可以了解看看。
这篇文章给大家分享的是用CSS怎样实现表单验证的方法。在实际的项目中,表单验证是个很常见的需求,例如登录注册这些都会使用到表单验证。这里我们主要看如何纯CSS实现,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008