• css变量的用法——(--cssName)


    CSS变量,又称——CSS自定义属性,现在很多CSS预处理/后处理程序已作了相关快捷的编译处理, 

    基本用法有哪些呢,我们先看一个简单的栗子;——要求,创建一个五个块元素居中的分栏样式,奇数和偶数同高不同宽。

    先看效果:

    上菜一:

    html:

    <!DOCTYPE html>
    <html>
    
        <head>
            <meta charset="utf-8" />
            <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
            <title>CSS变量的设置</title>
            <!--样式初始化————normalize 等同于reset.css-->
            <link rel="stylesheet" type="text/css" href="css/normalize.css" />
            <link rel="stylesheet" type="text/css" href="css/index.css" />
        </head>
        <body>
            <!--快速创建列表-->
            <!--ul[class="wrap"]>li[id="a$"]{块$}*5--> 
            <ul class="wrap">
                <li id="a1">块1</li>
                <li id="a2">块2</li>
                <li id="a3">块3</li>
                <li id="a4">块4</li>
                <li id="a5">块5</li>
            </ul>
        </body>
    </html>

    上硬菜:

    css:

    body {
         100%;
        font-size: 20px;
    }
    
    :root {
        --w1: 10rem;
        --w2: 15rem;
        --R: red;
        --G: green;
        --W: #ffffff;
        --Gr: grey;
        --position: center;
        --b: 1px solid #000;
    }
    
    .wrap {
        font-size: 0px;
         100%;
        height: auto;
        text-align: var(--position);
    }
    
    .wrap li {
        color: var(--W);
        vertical-align: middle;
        display: inline-block;
        --a: calc(var(--w2) + var(--w1));
        height: calc( var(--a)*2.5);
        line-height:calc( var(--a)*2.5);
        border: var(--b);
    }
    
    li:nth-child(odd) {
        font-size: 2rem;
         var(--w1);
        background-color: var(--R);
    }
    
    li:nth-child(even) {
        font-size: 3rem;
         var(--w2);
        background-color: var(--G);
    }

    由“菜一”可以看出,css变量的用法,基本普通html代码编译方式一样,采用css引入方式,由“硬菜”可以看出,变量的用法,也就是类似于rem的用法,不过可以随意设置前缀为“--”(双短杠)的任意变量名,同时可以配合rem,百分比,px等来使用

    所以优点显而易见:

    1.一次设置,多次调用,且调用对象不限,id=a的元素可以用,id=b的元素也可以用;

    2.调试时,可以将相同的设置的元素,同时修改样式,快捷方便

    不过也有部分不足:

    1.当同一样式的元素,需要修改为不同的样式时候,必须删除变量或者另增加变量,盲目修改变量参数,会引起引用同一变量的其他元素样式变化,不利于元素的“个性化”调试;

    2.变量命名,区分大小写,--a和--A是不同的变量,类似js规则,而且“--”必须前置,注意的细节较多

    而且现在有很多css预编译工具,Less、SaSS等都带有此类功能,不过此处,我们只做原生的原理性用法的基本探究。

    相关链接:

    normalize.css:  http://necolas.github.io/normalize.css/

    css变量学习:https://www.w3cplus.com/css3/css-properties-in-depth.html?utm_source=tuicool&utm_medium=referral

  • 相关阅读:
    2022 flag 150篇文章 63 ES elastic search
    2022 flag 150编文章 005 java 网络编程
    2022 flag 150篇文章 91 分布式系统协调服务 分布式基础
    2022 flag 150篇文章 50 PMP
    2022 flag 150篇文章 61 消息队列 Kafka
    2022年1月最新最全的微前端框架调研
    sqlconnection,sqlcommand,sqldataadapter,sqldatareader,dataset的关系详解
    [日常] 解决docker拉取镜像速度慢的问题
    jupyter notebook下python2和python3共存(kali)
    Jboss弱密码及反序列化漏洞
  • 原文地址:https://www.cnblogs.com/chig/p/8287143.html
Copyright © 2020-2023  润新知