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


    所有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- 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 */
    }

    豌豆资源搜索网站https://55wd.com 广州vi设计公司http://www.maiqicn.com

    二、不固定值unset

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

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

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

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

    三、简单提一提revert

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

  • 相关阅读:
    JAVA周二学习总结
    2019春总结作业
    第十二周作业
    第十一周作业
    第十周作业
    第九周作业
    第八周作业
    第七周作业
    第六周作业
    第四周课程总结&试验报告(二)
  • 原文地址:https://www.cnblogs.com/qianxiaox/p/13740668.html
Copyright © 2020-2023  润新知