js修改scss变量

 style.scss

$color : var(--color,'#ccc');
// 默认值 #ccc
.color{
  background: $color;
}

        定义了一个scss变量($color),用普通的css变量(--color)给他赋值,这里需要一个默认值,此时css变量(--color)还没有定义,接下来只有通过js修改css变量(--color),那么scss变量($color)就会改变,但是要注意,scss变量($color)是全局生效的,也就是说不管是在哪里修改了scss变量($color),全局的scss变量($color)都会变化,(这个效果常用来修改全局的主题)

修改实现流程: js--->css--->scss

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>js修改scss变量</title>
  <link rel="stylesheet" href="style.css">
</head>
<body>
  <div class="color"></div>
  <button onclick="changeColor()">修改scss变量</button>
</body>
<script>
  function changeColor(){
    if(document.body.style.getPropertyValue('--color')!='red'){
      console.log(document.body.style.getPropertyValue('--color'));
      document.body.style.setProperty('--color', 'red');
    }else{
      console.log(document.body.style.getPropertyValue('--color'));
      document.body.style.setProperty('--color', 'gray');
    }
    
  }
</script>
</html>

         代码很简单,主要是在body修改css变量(--color) 因为页面中body的所有子元素会自动继承css变量(--color),这样即使有多个元素都会引起变化

这里点击一次按钮,div的颜色就变化一次

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值