当前位置: 首页 > news >正文

vue3 使用css变量

虽然 v-bind() 很方便,但当需要处理多个相关联的样式变量时,使用css变量

<template><button class="btn" :style="styleVars">点击我</button><button @click="changeColor">改变颜色</button>
</template><script setup>
import { ref, computed } from'vue'
// 主色调
const themeColor = ref('#409EFF')
// 根据主题色计算阴影颜色
const shadowColor = computed(() => {// 简单示例:实际应用中可以用更精确的颜色计算return`${themeColor.value}40`// 添加透明度})// // 集中管理所有样式变量
})
const styleVars = computed(() => ({'--btn-bg': themeColor.value,'--btn-text-color': '#fff','--btn-shadow': `0 4px 10px ${shadowColor.value}`}))const changeColor = () => {themeColor.value = themeColor.value === '#409EFF' ? '#f56c6c' : '#409EFF'
}</script><style scoped>
/* :root{--btn-bg: red;--btn-text-color: #fff;--btn-shadow: 0 4px 10px rgba(64, 158, 255, 0.4);
} */
.btn {background-color: var(--btn-bg);color: var(--btn-text-color);box-shadow: var(--btn-shadow);padding: 10px 20px;border: none;border-radius: 4px;transition: all 0.3s ease;
}.btn:hover {opacity: 0.9;
}
</style>

Vue 3 提供了 v-bind() 函数,让我们可以直接在 CSS 中使用 JavaScript 变量:

<template>
<p>示例文字</p>
</template><scriptsetup>
import { ref } from'vue'
const textColor = ref('red')
</script><stylescoped>
p {
color: v-bind('textColor');
}
</style>

缺点:用完 v-bind('响应式变量后') 会在每一个元素加这个键名,而自定义的变量不会

CSS 变量的命名规则如下:

  1. 必须以两个连字符开头:--

    • 例如:--main-color--font-size
  2. 只能包含字母、数字、连字符(-)和下划线(_),不能包含空格或其他特殊字符。

  3. 区分大小写,但建议全部小写,便于统一管理。

  4. 命名建议有语义,体现用途或作用,例如:

    • --primary-bg
    • --header-height
    • --button-radius
  5. 可以使用驼峰或连字符风格,但推荐连字符风格(如 --main-color

<template><button class="btn" :style="styleVars">点击我</button><button @click="changeColor">改变颜色</button><p class="text">示例文字</p>
</template><script setup>
import { ref, computed } from'vue'
// 主色调
const themeColor = ref('#409EFF')
const textColor = ref('red')
// 根据主题色计算阴影颜色
const shadowColor = computed(() => {// 简单示例:实际应用中可以用更精确的颜色计算return`${themeColor.value}40`// 添加透明度})// // 集中管理所有样式变量
})
const styleVars = computed(() => ({'--btn-bg': themeColor.value,'--btn-text-color': '#fff','--btn-shadow': `0 4px 10px ${shadowColor.value}`}))const changeColor = () => {themeColor.value = themeColor.value === '#409EFF' ? '#f56c6c' : '#409EFF';textColor.value = textColor.value === 'red' ? 'blue' : 'red';
}</script><style scoped>
/* :root{--btn-bg: red;--btn-text-color: #fff;--btn-shadow: 0 4px 10px rgba(64, 158, 255, 0.4);
} */
.btn {background-color: var(--btn-bg);color: var(--btn-text-color);box-shadow: var(--btn-shadow);padding: 10px 20px;border: none;border-radius: 4px;transition: all 0.3s ease;
}.btn:hover {opacity: 0.9;
}.text{color: v-bind('textColor')
}
</style>


文章转载自:

http://Xfip0Jng.jbbLf.cn
http://ZaopD7nQ.jbbLf.cn
http://JGgAdE3Y.jbbLf.cn
http://EQynEpra.jbbLf.cn
http://s7USpr2U.jbbLf.cn
http://kA7TOVxd.jbbLf.cn
http://BmJZ4ngW.jbbLf.cn
http://Xws6nmEW.jbbLf.cn
http://zsEZmd37.jbbLf.cn
http://rCyq1dhY.jbbLf.cn
http://mJ7Eg8d4.jbbLf.cn
http://KF1g2KEW.jbbLf.cn
http://xNIFClRs.jbbLf.cn
http://pD2nFQ0b.jbbLf.cn
http://f6PeKBIj.jbbLf.cn
http://9nKL8kbg.jbbLf.cn
http://PvlFQMDn.jbbLf.cn
http://QP0cddE5.jbbLf.cn
http://gDslVPYx.jbbLf.cn
http://m3KbkJaw.jbbLf.cn
http://acZOJdwA.jbbLf.cn
http://em1IibwX.jbbLf.cn
http://4EORE9VJ.jbbLf.cn
http://fkDctdo9.jbbLf.cn
http://U2CIK25f.jbbLf.cn
http://XnJFxQQa.jbbLf.cn
http://ykMYbbGn.jbbLf.cn
http://7cz48PME.jbbLf.cn
http://HBjQBrr5.jbbLf.cn
http://GJF4SrBj.jbbLf.cn
http://www.dtcms.com/a/364238.html

相关文章:

  • CSS Sass Less 样式.xxx讲解
  • 代码随想录算法训练营第四天|链表part02
  • Windows 10/11 系统 vcruntime140.dll 故障终极解决:从重装组件到系统修复的完整流程
  • 飞算JavaAI真能帮小白搞定在线图书借阅系统?开发效果大揭秘!
  • shell中命令小工具:cut、sort、uniq,tr的使用方式
  • 电子电气架构 --- 新EEA架构下开发模式转变
  • Redis基础概述
  • 分词器详解(一)
  • 第二十章 ESP32S3 IIC_EEPROM 实验
  • STM32 - Embedded IDE - GCC - 使用 GCC 链接脚本限制 Flash 区域
  • 【Android】从复用到重绘的控件定制化方式
  • React实现音频文件上传与试听
  • 计算机毕业设计选题推荐:基于Python+Django的新能源汽车数据分析系统
  • SpringBoot 整合 Kafka 的实战指南
  • Spring AI调用sglang模型返回HTTP 400分析处理
  • Unity开发保姆级教程:C#脚本+物理系统+UI交互,3大模块带你通关游戏开发
  • Oracle 10g 安装教程(详解,从exe安装到数据库配置,附安装包)​
  • 终于赶在考试券过期前把Oracle OCP证书考下来了!
  • 使用 PHP Imagick 扩展实现高质量 PDF 转图片功能
  • 字节跳动把AI大模型入门知识点整理成手册了,高清PDF开放下载
  • 嵌入式解谜日志-网络编程(udp,tcp,(while循环原理))
  • 【C语言指南】回调函数:概念与实际应用的深度剖析
  • 深度学习——基于卷积神经网络实现食物图像分类之(保存最优模型)
  • leetcode-每日一题-人员站位的方案数-C语言
  • 基于飞算JavaAI的在线图书借阅平台设计与实现
  • 基于单片机雏鸡孵化恒温系统/孵化环境检测系统设计
  • GPIO的8种工作方式
  • 安装wsl报错0x800701bc
  • OCR识别在媒资管理系统的应用场景剖析与选择
  • 今天我们继续学习shell编程语言的内容