用CSS变量修改样式怎样做,代码是什么
Admin 2022-05-28 群英技术资讯 1029 次浏览
这篇文章主要介绍了用CSS变量修改样式怎样做,代码是什么相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇用CSS变量修改样式怎样做,代码是什么文章都会有所收获,下面我们一起来看看吧。问题
js怎么去修改css伪类样式呢?但是js并没有伪类选择器,那么该怎么办呢?网上有不少方法,比如通过切换元素的类、在style中动态插入新的样式等。
那么这里再来一种方法,设置css变量(var),通过js去改变这个变量来实现。
示例:改变div的hover背景色
<!-- css -->
<style type="text/css">
:root {
--divHoverColor: red;
}
div {
width: 100px;
height: 100px;
background: bisque;
}
div:hover {
background: var(--divHoverColor);
}
</style>
<!-- html -->
<div onClick="onDivClick('green')"/>
<!-- js -->
<script type="text/javascript">
function onDivClick(value){
document.documentElement.style.setProperty('--divHoverColor', value);
}
</script>
那么,来认识下css variable吧
1. 基本用法
局部变量
div {
--masterColor: red;
background: var(--masterColor);
}
全局变量
/* 对于HTML来说,:root 表示 <html> 元素 */
:root {
--masterColor: red;
}
div {
background: var(--masterColor);
}
2. 语法
var( <custom-property-name> [, <declaration-value> ]? )
<custom-property-name> : 自定义属性名
<declaration-value> : 声明值(fallback value)
示例:
div {
/*
--masterColor未定义,所以背景色使用red
它可以通过逗号分隔,定义多个声明值,var(--masterColor, red, green)
*/
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)) {
/* supported */
}
@supports ( not (--masterColor: red)) {
/* not supported */
}
使用JS检测
const isSupported = window.CSS && window.CSS.supports
&& window.CSS.supports('--masterColor', 'red');
if (isSupported) {
/* supported */
} else {
/* not supported */
}
参考
MDN
CSS Variable 规范
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了CSS子元素跟父元素的高度一致的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
一些朋友对innerHTML的使用比较好奇,但又找不到比较合适的方法,接下来的时间不妨看看爱站技术频道小编所整理的资料,或多或少能在工作中帮助到大家。
将原本的鼠标指针样式,修改成自己想要的效果,并且添加上一些特殊的交互效果。修改鼠标样式首先,第一个问题,我们可以看到,上图中,鼠标指针的样式被修改成了一个圆点:正常而言应该是
其中伪类和伪元素(伪对象)的根本区别在于:它们是否创造了新的元素。伪元素/伪对象:不存在在DOM文档中,是虚拟的元素,是创建新元素。代表某个元素的子元素,这个子元素虽然在逻辑上存
本篇文章主要介绍了css-解决font-weight:blod跳动问题的解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008