CSS 样式的 initial(默认)和 inherit(继承)以及 unset

本文详细介绍了CSS属性值initial、inherit和unset的使用方法及技巧,包括它们如何影响样式继承和默认值设置,并通过实例展示了这些关键字的实际应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

经常会碰到,问一个 CSS 属性,例如 position 有多少取值。

通常的回答是 staticrelativeabsolute 和 fixed 。当然,还有一个极少人了解的 sticky 。其实,除此之外, CSS 属性通常还可以设置下面几个值:

  • initial
  • inherit
  • unset
  • revert
1
2
3
4
5
6
7
8
{
   position : initial;
   position : inherit;
   position : unset
   /* CSS Cascading and Inheritance Level 4 */
   position : revert;
}

了解 CSS 样式的 initial(默认)和 inherit(继承)以及 unset 是熟练使用 CSS 的关键。(当然由于 revert 未列入规范,本文暂且不过多提及。)

initial

initial 关键字用于设置 CSS 属性为它的默认值,可作用于任何 CSS 样式。(IE 不支持该关键字)

inherit

每一个 CSS 属性都有一个特性就是,这个属性必然是默认继承的 (inherited: Yes) 或者是默认不继承的 (inherited: no)其中之一,我们可以在 MDN 上通过这个索引查找,判断一个属性的是否继承特性。

譬如,以 background-color 为例,由下图所示,表明它并不会继承父元素的 background-color:

可继承属性

最后罗列一下默认为 inherited: Yes 的属性:

  • 所有元素可继承:visibility 和 cursor
  • 内联元素可继承:letter-spacing、word-spacing、white-space、line-height、color、font、 font-family、font-size、font-style、font-variant、font-weight、text- decoration、text-transform、direction
  • 块状元素可继承:text-indent和text-align
  • 列表元素可继承:list-style、list-style-type、list-style-position、list-style-image
  • 表格元素可继承:border-collapse

还有一些 inherit 的妙用可以看看这里:谈谈一些有趣的CSS题目(四)-- 从倒影说起,谈谈 CSS 继承 inherit,合理的运用 inherit 可以让我们的 CSS 代码更加符合 DRY(Don‘’t Repeat Yourself )原则。

unset

名如其意,unset 关键字我们可以简单理解为不设置。其实,它是关键字 initial 和 inherit 的组合。

什么意思呢?也就是当我们给一个 CSS 属性设置了 unset 的话:

  1. 如果该属性是默认继承属性,该值等同于 inherit
  2. 如果该属性是非继承属性,该值等同于 initial

举个例子,根据上面列举的 CSS 中默认继承父级样式的属性,选取一个,再选取一个不可继承样式:

  • 选取一个可继承样式: color
  • 选取一个不可继承样式: border

使用 unset 继承/取消样式:

看看下面这个简单的结构:

1
2
3
4
< div  class="father">
     < div  class="children">子级元素一</ div >
     < div  class="children unset">子级元素二</ div >
</ div >
1
2
3
4
5
6
7
8
9
10
11
12
13
14
.father {
     color red ;
     border 1px  solid  black ;
}
.children {
     color green ;
     border 1px  solid  blue ;
}
.unset {
     color : unset;
     border : unset;
}
  1. 由于 color 是可继承样式,设置了 color: unset 的元素,最终表现为了父级的颜色 red

  2. 由于 border 是不可继承样式,设置了 border: unset 的元素,最终表现为 border: initial ,也就是默认 border 样式,无边框。

CodePen Demo -- unset Demo;

unset 的一些妙用

例如下面这种情况,在我们的页面上有两个结构类似的 position: fixed 定位元素。

区别是其中一个是 top:0; left: 0;,另一个是 top:0; right: 0;。其他样式相同。

假设样式结构如下:

1
2
3
4
< div  class="container">
     < div  class="left">fixed-left</ div >
     < div  class="right">fixed-right</ div >
</ div >

通常而言,样式如下:

1
2
3
4
5
6
7
8
9
10
11
12
. left ,
. right  {
     position fixed ;
     top 0 ;   
     ...
}
. left  {
     left 0 ;
}
. right  {
     right 0 ;
}

使用 unset 的方法:

1
2
3
4
5
6
7
8
9
10
11
. left ,
. right  {
     position fixed ;
     top 0 ;   
     left 0 ;
     ...
}
. right  {
     left : unset;
     right 0 ;
}

CodePen Demo -- unset Demo;

到此本文结束,如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

文章转载:谈谈一些有趣的CSS题目(十五)-- 谈谈 CSS 关键字 initial、inherit 和 unset - ChokCoco - 博客园

### CSS 文本对齐属性值的使用说明 `text-align` 是一个用于控制块级元素内文本水平对齐方式的 CSS 属性。以下是该属性的常见值及其作用[^1]: - **left**:将文本左对齐,这是默认值。 - **right**:将文本右对齐。 - **center**:将文本居中对齐。 - **justify**:将文本两端对齐,行的开头结尾被拉伸以使它们之间的空间相等[^2]。 - **initial**:将属性设置为其默认值,通常为 `left`。 - **inherit**:子元素从父元素继承 `text-align` 的值。 - **unset**:将属性重置为其默认行为,具体取决于它是否可继承。 - **revert**:将属性重置为用户代理样式表或浏览器的默认值。 #### 示例代码 以下是一个简单的示例,展示如何在 HTML CSS 中使用 `text-align` 属性: ```css /* 定义不同对齐方式 */ .align-left { text-align: left; } .align-right { text-align: right; } .align-center { text-align: center; } .align-justify { text-align: justify; } ``` ```html <div class="align-left">这是左对齐文本。</div> <div class="align-right">这是右对齐文本。</div> <div class="align-center">这是居中文本。</div> <div class="align-justify">这是两端对齐文本。通过两端对齐,可以确保每行的开头结尾都对齐。</div> ``` ### 常见错误提示及解决方法 如果在使用 `text-align` 属性时遇到错误提示,可能是由于以下原因导致: 1. **拼写错误**:检查属性名称或值是否拼写正确。例如,`text-algin` 应为 `text-align`[^3]。 2. **无效的选择器**:确保 CSS 选择器能够正确匹配目标 HTML 元素。 3. **继承问题**:某些情况下,子元素可能未正确继承父元素的 `text-align` 属性值。可以通过显式定义 `inherit` 或 `unset` 来解决。 4. **浏览器兼容性**:虽然 `text-align` 是广泛支持的标准属性,但某些特殊值(如 `revert`)可能在旧版浏览器中不受支持[^4]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值