css的属性是变量是怎么表达,CSS自定义变量属性——像less,sass那样在css中使用变量(译)...

初步使用

:root {

--main-color: #06c;

--accent-color: #006;

}

/* The rest of the CSS file */

#foo h1 {

//引用变量

color: var(--main-color);

}

以下使用方法错误!!!

他错误地尝试使用变量名代替属性名:

.foo {

--side: margin-top;

var(--side): 20px;

}

这并不能实现margin-top: 20px,会抛出语法错误。

大小写敏感

尽管--FOO与--foo都是合法的变量,但是当你引用前者指代的就是前者的值,后者亦然。

h1 {

--font-color: lightblue;

--Font-color: lightgreen;

color: var(--Font-color);

//lightgreen

}

设置值的注意事项

自定义属性可以以!important结尾, 但是CSS解析器会自动移除这个属性的值,并按瀑布流的形式确定其优先属性。换句话说,虽然可以使用!important,但是顶级优先“!”的禁止其它同类CSS生效的作用并没有实现CSS。

h1 {

--font-color: lightblue!important;

--Font-color: lightgreen;

color: var(--font-color);

color: var(--Font-color);

//lightgreen

}

继承性与优先级(可正常理解)

:root { --color: blue; }

div { --color: green; }

#alert { --color: red; }

* { color: var(--color); }

I inherited blue from the root element!

//blue
I got green set directly on me!
//green

While I got red set directly on me! //red

I’m red too, because of inheritance!

//red

可与正常属性混用

:root {

--main-color: #c06;

--accent-background: linear-gradient(to top, var(--main-color), white);

}

互相调用无效

body {

font-size: 16px;

}

//h1最终大小为16px

h1 {

--font-color: lightblue!important;

--Font-color: lightgreen;

--one: calc(var(--two) + 30px);

--two: calc(var(--one) - 50px);

color: var(--font-color);

color: var(--Font-color);

font-size: var(--one);

}

在不同范围内合法,事实上两者在不同范围内指代了不同的变量

one { --foo: 10px; } //10

two { --bar: calc(var(--foo) + 10px); } //20

three { --foo: calc(var(--bar) + 10px); } //30

calc()使用通用的数学运算规则,但是也提供更智能的功能:

使用“+”、“-”、“*” 和 “/”四则运算;

可以使用百分比、px、em、rem等单位;

可以混合使用各种单位进行计算;

表达式中有“+”和“-”时,其前后必须要有空格,如"widht: calc(12%+5em)"这种没有空格的写法是错误的;

表达式中有“*”和“/”时,其前后可以没有空格,但建议留有空格。

变量初始默认值

.component .header {

color: var(--header-color, blue);

}

.component .text {

color: var(--text-color, black);

}

/* In the larger application’s style: */

.component {

--text-color: #080;

/* header-color 为默认值blue

注: var(--header-color, blue, red)无效

*/

}

变量的替换使用规范

var()并不是按照原文替换CSS字符

.foo {

--gap: 20;

margin-top: var(--gap)px;

}

这无法设置margin-top: 20px;(a length),而是等同于margin-top: 20 px; (a number followed by an ident空格),这是一个不合法的属性值. 不过, calc()可以实现:

.foo {

--gap: 20;

margin-top: calc(var(--gap) * 1px);

}

下面的代码从语法上江是无错误的,但是并无实际效果。因为20px并不是一个背景色的有效值,如果没有其他设置(必须优先级高于这里的设置)或继承的背景色,将会使用全局默认的透明背景色。

:root { --not-a-color: 20px; }

p { background-color: red; }

p { background-color: var(--not-a-color); }

//这里虽然有背景色的设置但是优先级并没有自定义属性的高,故而`p`的背景色是透明色

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/564063.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis的超时命令和垃圾回收策略

正如 Java 虚拟机,它提供了自动 GC(垃圾回收)的功能,来保证 Java 程序使用过且不再使用的 Java 对象及时的从内存中释放掉,从而保证内存空间可用。 当程序编写不当或考虑欠缺的时候(比如读入大文件&#x…

小米微信无法连接到服务器1-10087,微信无法连接到服务器【搞定方向】

win7系统电脑使用过程中有不少朋友表示遇到过微信无法连接到服务器的状况,当出现微信无法连接到服务器怎么样才能快速解决呢?其实解决微信无法连接到服务器也是非常简单的。网上有各种各样的解决方法,我给大家详细介绍一下关于微信无法连接到…

服务器虚拟机的固定ip怎么设置,虚拟机还能设置静态ip?Vmware 虚拟机配置全攻略...

前言:虚拟机应该是我们大多数人都会接触到的,尽管目前虚拟机的配置都十分简单便捷,几乎可以说是上手即用。但是对于一些较不常用的操作,可能配置起来还是会繁琐一些,比如解锁 macOS 的安装限制 ,设置 静态 …

Redis流水线性能提高

我们希望在没有任何附加条件的场景下去使用队列批量执行一系列的命令,从而提高系统性能,这就是 Redis 的流水线(pipelined)技术。而现实中 Redis 执行读/写速度十分快,而系统的瓶颈往往是在网络通信中的延时&#xff0…

ajax离开页面方法,如果用户在页面加载完成之前离开页面,则触发jQuery ajaxError()处理程序...

我们使用jQuery的全局ajaxError()处理函数来警告用户任何AJAX失败:$(document).ajaxError(function() {$("There was a network or server error. Please try again later.").dialog({title: "Error",modal: true,resizable: false,buttons: { …

Redis中使用Lua语言

在 Redis 的 2.6 以上版本中,除了可以使用命令外,还可以使用 Lua 语言操作 Redis。从前面的命令可以看出 Redis 命令的计算能力并不算很强大,而使用 Lua 语言则在很大程度上弥补了 Redis 的这个不足。 只是在 Redis 中,执行 Lua …

服务器预装操作系统,服务器预装操作系统吧

服务器预装操作系统吧 内容精选换一换镜像是一个包含了软件及必要配置的服务器或磁盘模版,包含操作系统或业务数据,还可以包含应用软件(例如,数据库软件)和私有软件。镜像分为公共镜像、私有镜像、共享镜像、市场镜像。镜像服务(Image Manage…

Redis的两种备份方式:RDB和AOF

在 Redis 中存在两种方式的备份:一种是快照恢复(RDB),通过快照(snapshotting)实现的,它是备份当前瞬间 Redis 在内存中的数据记录。 另一种是只追加文件(Append-Only File&#xff…

C 创建链表

C语言创建链表 完整代码 #include<stdio.h> #include<stdlib.h> #include<malloc.h> typedef struct LNode{int data;struct LNode *next; }LNode,*LinkList;LinkList CreateList(int n); void print(LinkList h); int main() {LinkList HeadNULL…

刀片服务器显示连接线,通过浏览器对刀片服务器进行管理

为了通过浏览器的方式对刀片服务器进行管理&#xff0c;第一步是通过cat5类线连接管理模块的以太网口&#xff0c;或者通过直连线进行连接。在浏览器中敲入管理模块的固定ip 地址(192.168.70.125)进行连接&#xff0c;如果存在dhcp服务&#xff0c;需要在dhcp服务器端查看管理模…

Redis内存回收策略

Redis 也会因为内存不足而产生错误&#xff0c;也可能因为回收过久而导致系统长期的停顿&#xff0c;因此掌握执行回收策略十分有必要。在 Redis 的配置文件中&#xff0c;当 Redis 的内存达到规定的最大值时&#xff0c;允许配置 6 种策略中的一种进行淘汰键值&#xff0c;并且…

visual报表服务器项目,为 Visual Studio ALM 创建报表服务器项目

为 Visual Studio ALM 创建报表服务器项目06/09/2015本文内容通过使用 SQL Server 报表设计器来创建报表可以跟踪团队的进度。 在可以使这些报表基于 Visual Studio Team Foundation Server (TFS) 中的数据之前&#xff0c;必须首先在 Visual Studio 中创建一个报表服务器项目。…

Redis悲观锁、乐观锁和调用Lua脚本的优缺点

悲观锁使用了数据库的锁机制&#xff0c;可以消除数据不一致性&#xff0c;对于开发者而言会十分简单&#xff0c;但是&#xff0c;使用悲观锁后&#xff0c;数据库的性能有所下降&#xff0c;因为大量的线程都会被阻塞&#xff0c;而且需要有大量的恢复过程&#xff0c;需要进…

从RedisTemplate中获得Jedis实例

很多时候&#xff0c;我们也许需要使用一些更为高级的缓存服务器的 API&#xff0c;如 Redis 的流水线、事务和 Lua 语言等&#xff0c;所以也许会使用到 RedisTemplate 本身。 首先&#xff0c;定义 RedisTemplateService 的接口&#xff0c;代码如下所示。 package com.ser…

Spring整合Redis详解

用注解驱动的方式来使用 Redis。和数据库事务一样&#xff0c;Spring 提供了缓存的管理器和相关的注解来支持类似于 Redis 这样的键值对缓存。 准备测试环境 首先&#xff0c;定义一个简单的角色 POJO&#xff0c;代码如下所示。 package com.pojo; import java.io.Serializ…

Redis和数据库的结合

使用 Redis 可以优化性能&#xff0c;但是存在 Redis 的数据和数据库同步的问题&#xff0c;这是我们需要关注的问题。假设两个业务逻辑都是在操作数据库的同一条记录&#xff0c;而 Redis 和数据库不一致。 Redis 和数据库不一致 在图中&#xff0c;T1 时刻以键 key1 保存数…

C 字符串排序

使用C语言对字符串进行排序 编写程序对字符串进行排序输出&#xff0c;用户根据提示输入三个字符串&#xff0c;程序根据26个英文字母的顺序进行排序输出。 完整代码 #include<stdio.h> #include<stdlib.h> #include <string.h>void swap(char*str1,char*…

plsql连接报ORA-12537

客户新电脑装上了plsql&#xff0c;连接数据库时报如上错误&#xff0c;但是别的电脑都可以正常连接&#xff0c;先检查了下TNS配置&#xff0c;发现没问题&#xff0c;数据库连接数也足够&#xff0c;百思不得其解 后面去数据库服务器上查看了监听日志文件&#xff0c;连接报错…

C 将任意八进制数转化为十进制

C语言实现八进制数到十进制的转化 使用C语言将一个八进制数转化为十进制数&#xff0c;用户根据提示输入一个任意的八进制数&#xff0c;程序将八进制数转化为十进制数并进行输出显示。 完整代码 #include<stdio.h> #include<stdlib.h> int main() {int n0,i0;c…

C 字符串连结

C语言实现对两个字符串进行连接 用户根据提示分别输如两个任意的字符串&#xff0c;两个字符串之间要用回车分开&#xff0c;程序将这两个字符串进行连接并输出显示。 完整代码 #include <stdio.h> #include<stdlib.h> #include<string.h>char* strconnec…