CSS inherit是继承,那initial和unset呢?

更新日期: 2020-01-01阅读: 2.4k标签: 继承

所有css都支持几个全局属性值,分别是: inherit , initial 和 unset 。其中 inherit 是继承的意思,IE8(标准版)开始支持,不是从IE9开始支持的,网上一些文档是错误的。 inherit 是非常好用的一个CSS属性。

例如:

input, textarea {
    font-family: inherit;
}

或者子元素 height:inherit 或者背景 background 继承等,都是非常实用的场景。那 initial 和 unset 这两个关键字值是什么意思呢?很多前端开发人员就不知道了。


一、初始值initial

initial 表示初始值的意思。举几个例子看看其细节表现。

案例1:font-size与initial

测试代码如下:

<ul style="font-size:12px;border:1px solid deepskyblue;">
    <li>#朱一龙追梦人#   <small class="ml20">1亿</small></li>
    <li>#宠爱票房#   <small class="ml20">3亿</small></li>
    <li>#张艺兴醉拳舞# <small class="ml20">1亿</small></li>
    <li>#肖战余年MV# <small class="ml20">2亿</small></li>
    <li style="font-size:initial">#张鑫旭中大鱼# <small class="ml20">233</small></li>
</ul>


案例2:漂亮的button一秒变丑

有个美美的按钮,写了很多CSS:

.ui-button {
    display: inline-block;
    line-height: 20px;
    font-size: 14px;
    text-align: center;
    color: #4c5161;
    border-radius: 4px;
    padding: 10px 15px;
    min-width: 80px;
    border: none;
    background-color: #2a80eb;
    color: #fff;
    box-sizing: border-box;
    font-family: inherit;
    cursor: pointer;
    overflow: visible;
}
<button class="ui-button">美美的按钮</button>

然后这个按钮的实时效果如下:

你以为你大功告成,突然产品经理来了个需求,希望我们的页面增加一个叫原始皮肤的皮肤,在这个皮肤下面,所有的表单控件都是用原生的样子。

如果只要一个按钮还好,JS去掉类名 ui-button ,但是现在是整个页面换肤,有那么多的按钮,而且还有按钮说不定是在JS里面创建的,所以去除类名这种方式显得很麻烦。

有没有什么简单的办法呢?啊,很简单,一行CSS就可以了,如下示意:

<button class="ui-button" style="all: initial">美美的按钮</button>

all:initial 并不能把按钮还原成浏览器原始按钮UI。因为浏览器默认按钮CSS也是额外设置的,因此, all:initial 会把浏览器内置按钮的CSS也全部变成初始值了,什么 border 边框啊,什么 background 背景全部都没了,结果最后就是一个纯文本一样的按钮。

所以,漂亮的按钮一秒变丑,1秒是不可能的了,不过也不是没有办法,可以借助 :not() 伪类。

body:not('.initial') .ui-button {
    /* 美美的按钮相关CSS */
}


二、不固定值unset

unset表示不固定值,特性如下,当前元素浏览器或用户设置的CSS忽略,然后如果是具有继承特性的CSS,如 color , 则使用继承值;如果是没有继承特性的CSS属性,如 background-color, 则使用初始值。

还是按钮的例子,如果我们这样改造呢?

<button class="ui-button" style="all: unset">美美的按钮</button>

虽然看似一样,实际上还是有不同之处的,例如color文字颜色,前者纯黑,后者淡一些;又例如按钮的高度,由于line-height具有继承性,所以后面的按钮继承了当前文章所在的行高,而不是 normal 初始值。


三、简单提一提revert

revert 也是一个全局值,表示恢复,可以重置CSS属性为浏览器默认的样式,正好可以完美解决上面按钮1秒变丑的需求。

原文 https://www.zhangxinxu.com/wordpress/2020/01/css-initial-unset/

链接: https://fly63.com/article/detial/7148

js原型继承、构造函数继承、组合继承法

原型继承缺点:1、不能由子对象像父对象传递参数,2、对于引用型的属性修改之后会印象其他的实例对象;构造函数继承缺点:1、不能继承父对象原型上的方法 2、每次实例化对象会重新构建函数,浪费内存。

各种实现js继承的方法总结

学过java的同学应该都知道,继承是java的重要特点之一,许多面向对象的语言都支持两种继承方式:接口继承和实现继承,接口继承只继承方法签名,而实现继承则继承实际的方法,在js中,由于函数没有签名,因此支持实现继承,而实现继承主要是依靠原型链来实现的,那么,什么是原型链呢?

css的继承性

在面向对象语言都会存在继承的概念,在面向对象语言中,继承的特点:继承了父类的属性和方法。那么我们现在主要研究css,css就是在设置属性的。不会牵扯到方法的层面。

js原型继承的几种方式

1. 原型链继承;2,构造函数继承(对象冒充继承);3,组合继承(原型链继承+构造函数继承);4,原型式继承;5. 寄生组合式继承,为了解决引用共享和超类型无法传参的问题,我们采用一种叫借用构造函数的技术

Js继承背后的场景-prototype,__proto__, [[prototype]]

prototype是构造函数的一个属性,它决定了在构造出来的对象上__proto__属性将是什么样的。如上图所示,理解JavaScript中的继承的关键是要理解母鸡如何产蛋的过程。

Js常用的继承方式

JavaScript常用继承方式主要分为(7种):原型链继承、构造函数继承、组合继承、原型式继承、寄生式继承、寄生组合继承以及继承多个对象。原型链继承(核心:将父类的实例作为子类的原型

JS之继承(ES5 & ES6)

继承到底是什么?继承(英语:inheritance)是面向对象软件技术当中的一个概念。如果一个类别B“继承自”另一个类别A,就把这个B称为“A的子类”,而把A称为“B的父类别”也可以称“A是B的超类”。继承可以使得子类具有父类别的各种属性和方法

Js继承总结

当读取实例的属性时,如果找不到,就会查找与对象关联的原型中的属性,如果还查不到,就去找原型的原型,一直找到最顶层为止。如果让原型对象指向另一个类型的实例.....有趣的事情便发生了.

ES5 的构造函数原型链继承

构造函数,就是专门用来生成实例对象的函数。一个构造函数,可以生成多个实例对象,这些实例对象都有相同的结构。为了与普通函数区别,构造函数名字的第一个字母通常大写。

Js对象继承

JavaScript对象继承的方法有很多,这里总结一下几种比较常用的方法。使用call/apply和Object.create()第一种方法使用call或apply方法,改变了 this 的指向而实现继承,将父对象的构造函数绑定在子对象上,即在子对象构造函数中加一行

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!