动态修改el-input样式;动态修改elmentUI元素样式;css变量

本文介绍了如何在Vue中动态修改Element UI组件的样式,特别是当样式嵌套较深时。通过使用CSS变量,可以方便地改变el-input的字体颜色。首先解释了CSS变量的概念和用法,然后展示了如何在Vue组件中声明和使用变量,以及如何通过JS动态修改颜色值。最后,提供了一个Vue3的例子,演示了如何直接在模板中使用v-bind修改Element组件的样式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

场景:正常我们动态修改div元素的样式,使用:style和:class即可;但是我们想要动态修改element的组件样式时候,例如el-input字体颜色,由于el-input的样式嵌套很深,我们需要修改的实际是.el-input__inner这个样式的color,但是我们在html又没法拿到这个类名。

解决办法:使用css变量修改


一、css变量是什么?

1.css变量

css变量具体可以看这篇

注意:1.声明变量的时候,变量名前面要加两根连词线 –
2.变量使用var() 函数包裹,还可以使用第二个参数,表示变量的默认值。如果变量不存在,就会使用这个默认值

以下代码中,声明了两个变量: --shadow、--size

div {
    font-size: var(--size, 18px);
    box-shadow: var(--shadow);
}

二、修改el-input字体颜色

1.原先正常修改字体颜色

/deep/ .el-input__inner {
  color: red
}

2.动态修改el-input字体颜色

思路:
1.给css引入一个变量--inputColor

        /deep/ .el-input__inner {
          color: var(--inputColor); //使用css变量 注意变量前需要加 --
        }

2.vue声明一个变量颜色colorVal 例如 #606266

data (){
	return {
		colorVal: '#606266',
	}
}

3.需要修改的地方,为--inputColor变量赋值

<el-input v-model="valueStr" :style="{ '--inputColor': colorVal}"></el-input>

4.动态js修改colorVal即可

this.colorVal = 'red'

需要注意:--inputColor是css变量,帮助引导的,colorVal才是设置的样式值

3、以下代码可直接复制

<template>
  <div>
    <el-input v-model="valueStr" :style="{ '--inputColor': colorVal}" @input="change1"></el-input>
  </div>
</template>

<script>
export default {
  data () {
    return {
      valueStr: '',
      colorVal: '#606266',
    }
  },
  created () {
  
  },
  methods: {
    change1 () {
      var r = Math.floor(Math.random() * 256)
      var g = Math.floor(Math.random() * 256)
      var b = Math.floor(Math.random() * 256)
      // 设置随机色
      var color = '#' + r.toString(16) + g.toString(16) + b.toString(16)
      this.colorVal = color
    },
  },
}
</script>

<style lang="less" scoped>
/deep/ .el-input__inner {
  color: var(--inputColor); //使用css变量 注意变量前需要加 --
}
</style>

三、vue3里修改element组件样式

直接使用v-bind(变量)即可

let displayValue = ref(props.mode !== 'view' ? 'block' : 'none')



<style lang="scss" scoped>
:deep(.el-form-item__label:before) {
  display: v-bind(displayValue) !important;
}
</style>

总结

其他的组件或者组件库,动态修改样式,同样道理

### 解决 Vue3 和 Element Plus 中 `el-descriptions` 组件包裹 `el-input` 时样式穿透的问题 当使用 `el-descriptions` 包含 `el-input` 并尝试应用自定义样式时,可能会遇到样式无法生效的情况。这是因为 Element Plus 的组件默认会作用于 Shadow DOM 或者有更具体的 CSS 特异性设置。 #### 使用深类选择器(Deep Selector) 为了使外部样式能够影响到嵌套的子组件,可以采用 `/deep/` 或 `::v-deep` 深层级选择器来实现样式穿透: ```css <style scoped> /* 对于较新的版本 */ .el-descriptions /deep/ .el-input { width: 100%; } /* 另一种方式适用于某些特定场景 */ .el-descriptions ::v-deep(.el-input) { width: 100%; } </style> ``` 需要注意的是,在最新的 Vue 单文件组件 (SFC) 规范中推荐使用 `>>>` 替代 `/deep/` 来达到相同效果;然而对于 `<style scoped>` 块内的样式表来说,上述两种写法均能正常工作[^1]。 #### 利用全局样式覆盖 如果希望更加彻底地控制内部输入框的表现形式而不局限于单个页面,则可以在项目根目录下的公共样式文件里直接指定规则: ```css /* 放置在 main.css 或类似的全局样式文件中 */ .el-descriptions-item__content .el-input { /* 自定义属性 */ width: 100% !important; } ``` 这种方法虽然简单粗暴但是效率较低,并且可能会影响到其他地方同样结构的内容,因此建议谨慎使用并尽可能通过局部解决方案解决问题[^2]。 #### 修改组件库主题变量 Element Plus 提供了一种更为优雅的方法——即调整其内置的主题配置项。可以通过修改 LESS/SASS 文件中的相应参数来自定义外观而无需额外编写过多CSS代码。具体操作可参照官方文档关于定制化的部分说明[^3]。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值