场景:正常我们动态修改div元素的样式,使用:style和:class即可;但是我们想要动态修改element的组件样式时候,例如el-input字体颜色,由于el-input的样式嵌套很深,我们需要修改的实际是.el-input__inner这个样式的color,但是我们在html又没法拿到这个类名。
解决办法:使用css变量修改
css变量具体可以看这篇
注意:1.声明变量的时候,变量名前面要加两根连词线 –
2.变量使用var() 函数包裹,还可以使用第二个参数,表示变量的默认值。如果变量不存在,就会使用这个默认值
以下代码中,声明了两个变量: --shadow、--size
div {font-size: var(--size, 18px);box-shadow: var(--shadow);
}
/deep/ .el-input__inner {color: red
}
思路:
1.给css引入一个变量--inputColor
/deep/ .el-input__inner {color: var(--inputColor); //使用css变量 注意变量前需要加 --}
2.vue声明一个变量颜色
colorVal
例如 #606266
data (){return {colorVal: '#606266',}
}
3.需要修改的地方,为
--inputColor
变量赋值
4.动态js修改
colorVal
即可
this.colorVal = 'red'
需要注意:--inputColor
是css变量,帮助引导的,colorVal
才是设置的样式值
以下代码可直接复制
其他的组件或者组件库,动态修改样式,同样道理