vue3 css使用v-bind实现动态样式

vue3 css使用v-bind实现动态样式

html 复制代码
<template>
    <button @click="toggleTheme">切换主题</button>
    <div class="card"></div>
</template>

<script setup>
import { ref } from 'vue'

const primaryColor = ref('#007bff')
const isLarge = ref(false)
const height = ref(200)
const margin = ref(20)

function toggleTheme() {
  // 切换亮色/暗色主题
  if (primaryColor.value === '#007bff') {
    primaryColor.value = '#ffc107'
    isLarge.value = true
  } else {
    primaryColor.value = '#007bff'
    isLarge.value = false
  }
}
</script>

<style scoped>
.card {
  margin-top: v-bind('margin * 2 + "px"');
  width: v-bind('isLarge ? "300px" : "200px"');
  height: v-bind('height + "px"');
  background-color: v-bind(primaryColor);
}
</style>
相关推荐
笔COOL创始人3 分钟前
requestAnimationFrame 动画优化实践指南
前端·javascript·面试
sophie旭6 分钟前
性能监控之首屏性能监控小实践
前端·javascript·性能优化
+VX:Fegn08957 分钟前
计算机毕业设计|基于springboot + vue物流配送中心信息化管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·小程序·课程设计
北辰alk9 分钟前
一文解锁vue3中hooks的使用姿势
vue.js
北辰alk10 分钟前
vue3 如何监听路由变化
vue.js
北辰alk16 分钟前
Vue3 生命周期深度解析:从 Options API 到 Composition API 的完整指南
vue.js
Amumu1213821 分钟前
React 前端请求
前端·react.js·okhttp
内存不泄露22 分钟前
基于Spring Boot和Vue的企业办公自动化系统设计与实现
java·vue.js·spring boot·intellij-idea
北辰alk25 分钟前
toRef 和 toRefs 详解及应用
vue.js