Vue中CSS动态样式绑定

Vue中CSS动态样式绑定与注意事项_vue css动态绑定-CSDN博客

在 Vue 中,你不能直接在 CSS 中直接绑定 data 中的数据,因为 CSS 不是响应式的。但是,有几种方法可以实现根据 Vue 实例中的数据来动态地改变样式:

内联样式绑定

你可以使用 :style 绑定来动态地设置元素的样式。

复制代码
<template>  
  <div :style="{ color: activeColor, fontSize: fontSize + 'px' }">  
    Hello Vue  
  </div>  
</template>  

<script>  
export default {  
  data() {  
    return {  
      activeColor: 'red',  
      fontSize: 30  
    };  
  }  
};  
</script>

计算属性和绑定类名

如果你需要根据多个数据属性来计算样式,可以使用计算属性来返回对象,并使用 :class 绑定。

复制代码
<template>  
  <div :class="computedStyles">  
    Hello Vue  
  </div>  
</template>  

<script>  
export default {  
  data() {  
    return {  
      isActive: true,  
      isError: false  
    };  
  },  
  computed: {  
    computedStyles() {  
      return {  
        active: this.isActive,  
        error: this.isError  
      };  
    }  
  }  
};  
</script>  

<style scoped>  
.active {  
  color: green;  
}  

.error {  
  border: 1px solid red;  
}  
</style>

绑定到 CSS 类

你也可以直接绑定到预定义的 CSS 类名。

复制代码
<template>  
  <div :class="{'my-class': isActive}">  
    Hello Vue  
  </div>  
</template>  

<script>  
export default {  
  data() {  
    return {  
      isActive: true  
    };  
  }  
};  
</script>  

<style scoped>  
.my-class {  
  color: blue;  
}  
</style>

z

你可以使用对象语法或数组语法来绑定多个类。

复制代码
<template>  
  <div v-bind:class="{ active: isActive, 'text-danger': hasError }">  
    Hello Vue  
  </div>  
</template>  

<script>  
export default {  
  data() {  
    return {  
      isActive: true,  
      hasError: false  
    };  
  }  
};  
</script>  

<style scoped>  
.active {  
  color: green;  
}  

.text-danger {  
  color: red;  
}  
</style>

使用动态样式表

虽然不常见,但你也可以使用 JavaScript 动态地修改 <style> 标签的内容,但这通常不如使用 :style:class 绑定那么直观和易于维护。

注意:当你使用 scoped 样式时,Vue 会自动为每个组件添加一个唯一的属性,并只将这些样式应用于具有该属性的元素。如果你需要在子组件中覆盖这些样式,你可以使用 >>>/deep/ 选择器(取决于你的预处理器和 Vue 版本)。但请注意,这种方法应该谨慎使用,因为它可能会影响到其他组件的样式。

相关推荐
谷歌开发者12 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (一)
前端·chrome·学习
名字越长技术越强12 小时前
Chrome和IE获取本机ip地址
前端
天***889612 小时前
Chrome 安装失败且提示“无可用的更新” 或 “与服务器的连接意外终止”,Chrome 离线版下载安装教程
前端·chrome
半梦半醒*12 小时前
zabbix安装
linux·运维·前端·网络·zabbix
大怪v13 小时前
【搞发🌸活】不信书上那套理论!亲测Javascript能卡浏览器Reader一辈子~
javascript·html·浏览器
清羽_ls13 小时前
React Hooks 核心规则&自定义 Hooks
前端·react.js·hooks
你的人类朋友13 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
西陵13 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
Panda__Panda13 小时前
docker项目打包演示项目(数字排序服务)
运维·javascript·python·docker·容器·c#
10年前端老司机14 小时前
Promise 常见面试题(持续更新中)
前端·javascript