栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

通过CSS变量修改样式的方法示例

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

通过CSS变量修改样式的方法示例

问题

js怎么去修改css伪类样式呢?但是js并没有伪类选择器,那么该怎么办呢?网上有不少方法,比如通过切换元素的类、在style中动态插入新的样式等。

那么这里再来一种方法,设置css变量(var),通过js去改变这个变量来实现。

示例:改变div的hover背景色



    :root {
 --divHoverColor: red;
    }
    div {
 width: 100px;
 height: 100px;
 background: bisque;
    }
    div:hover {
 background: var(--divHoverColor);
    }






那么,来认识下css variable吧

1. 基本用法

局部变量

div {
    --masterColor: red;
    background: var(--masterColor);
}

全局变量


:root {
    --masterColor: red;
}
div {
    background: var(--masterColor);
}

2. 语法

var( [, ]? )

: 自定义属性名

: 声明值(fallback value)

示例:

div {
    
    background: var(--masterColor, red);
}

变量可以通过var()进行引用

示例:

div {
    --masterColor: red;
    --bgColor: var(--masterColor)
}

注意:属性名是不能使用变量的

错误示例:

div {
    --bg: background;
    var(--bg): red;
}

3. 浏览器支持

Can I use 

使用@support检测

@supports ( (--masterColor: red)) {
  
}
@supports ( not (--masterColor: red)) {
  
}

使用JS检测

const isSupported = window.CSS && window.CSS.supports 
    && window.CSS.supports('--masterColor', 'red');

if (isSupported) {
  
} else {
  
}

参考

MDN
CSS Variable 规范

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/215122.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号