Vue中动态样式绑定+CSS变量实现切换明暗主题功能——从入门到进阶
1.直接借助Vue的动态绑定样式绑定
Vue动态样式绑定
在Vue中,动态样式绑定是一种强大的功能,它允许开发者根据数据的变化动态地更新元素的样式。以下是对Vue动态样式绑定的详细知识梳理与详解:
一、基础知识
Vue的动态样式绑定主要通过v-bind:style
(或简写为:style
)指令来实现。通过该指令,可以将样式属性与Vue组件中的数据进行绑定,从而实现样式的动态变化。
二、对象语法
对象语法是动态样式绑定中最直观且常用的方法。它允许开发者通过对象的属性和值来动态设置样式。
- 基本用法
<template><div :style="styleObject">Hello World</div>
</template><script>
export default {data() {return {styleObject: {color: 'red',fontSize: '14px'}};}
};
</script>
在上面的例子中,styleObject
是一个包含样式属性和值的对象。当styleObject
的属性值发生变化时,<div>
元素的样式也会相应地发生变化。
- 驼峰式与短横线分隔式
Vue中的样式属性可以是驼峰式(如fontSize
)或短横线分隔式(如font-size
)。在模板中,推荐使用短横线分隔式,因为这与CSS中的写法保持一致。但在JavaScript对象中,由于驼峰式是标准的属性命名方式,所以也可以使用驼峰式。Vue会自动将驼峰式属性转换为短横线分隔式。
三、数组语法
数组语法允许开发者结合多个样式对象,这在需要组合多种条件下的样式时非常有用。
- 基本用法
<template><div :style="[baseStyles, overridingStyles]">Hello World</div>
</template><script>
export default {data() {return {baseStyles: {color: 'blue',fontSize: '14px'},overridingStyles: {color: 'green'}};}
};
</script>
在上面的例子中,baseStyles
和overridingStyles
是两个包含样式属性的对象。当它们被组合在一起并绑定到<div>
元素的style
属性上时,overridingStyles
中的样式会覆盖baseStyles
中相同属性的样式。
四、条件样式
条件样式允许开发者根据条件动态地改变样式。这可以通过三元表达式、计算属性或方法来实现。
- 三元表达式
<template><div :style="{ color: isActive ? 'green' : 'red' }">Hello World</div>
</template><script>
export default {data() {return {isActive: true};}
};
</script>
在上面的例子中,isActive
是一个条件变量。当isActive
为true
时,<div>
元素的文字颜色为绿色;当isActive
为false
时,文字颜色为红色。
- 计算属性
计算属性可以将复杂的样式逻辑封装起来,使模板更加简洁。
<template><div :style="computedStyles">Hello World</div>
</template><script>
export default {data() {return {isActive: true};},computed: {computedStyles() {return {color: this.isActive ? 'green' : 'red',fontSize: '14px'};}}
};
</script>
在上面的例子中,computedStyles
是一个计算属性,它根据isActive
的值动态计算样式并返回。
五、结合类名与内联样式
在Vue中,还可以将动态样式与外部样式表结合使用。这可以通过动态地添加或移除类名来实现。
- 对象语法绑定类名
<template><div :class="{ active: isActive }">Hello World</div>
</template><script>
export default {data() {return {isActive: true};}
};
</script><style>
.active {font-weight: bold;
}
</style>
在上面的例子中,当isActive
为true
时,<div>
元素会添加active
类名,从而应用.active
样式。
- 数组语法绑定多个类名
<template><div :class="[classOne, classTwo]">Hello World</div>
</template><script>
export default {data() {return {classOne: 'class-a',classTwo: 'class-b'};}
};
</script><style>
.class-a {color: red;
}.class-b {font-size: 20px;
}
</style>
在上面的例子中,classOne
和classTwo
是两个数据属性,它们的值分别是样式类名。通过数组语法,可以将这两个样式类同时应用到一个元素上。
六、实际应用场景
动态样式绑定在Vue中有广泛的应用场景,如:
- 响应式设计:根据屏幕尺寸动态调整样式。
- 交互效果:根据用户操作(如点击、悬停)动态改变样式。
- 状态显示:根据数据状态(如错误提示、成功信息)动态应用样式。
- 主题切换:根据用户选择动态切换不同的主题样式。
七、主题切换实现
<template><el-header class="header" :style="style1"></el-header>
</template>
<script setup lang="ts">
const variables = reactive({//默认主题颜色'dark': '#374151',//鲜明色'light': '#ffffff'
})
const curTheme=ref("dark")let color=computed(()=>{return variables[curTheme.value];
})
// 使用 computed 动态计算样式
const style1 = computed(() => {return {'background-color': color.value}
})
const toggleTheme=()=>{
curTheme.value=curTheme.value==="dark"?"light":"dark";
}
</script>
<style>
.header {display: flex;justify-content: space-between;align-items: center;color: white;padding: 0 20px;height: 7%;
}
</style>
2.Vue中样式绑定动态变量传递给CSS {’–bg’:color}
Vue中CSS动态样式绑定
<template><el-header class="header" :style="{'--bg':color}"></el-header>
</template>
<script setup lang="ts">
const variables = reactive({//默认主题颜色'dark': '#374151',//鲜明色'light': '#ffffff'
})
const curTheme=ref("dark")let color=computed(()=>{return variables[curTheme.value];
})</script>
<style>
.header {display: flex;justify-content: space-between;align-items: center;color: white;padding: 0 20px;height: 7%;background-color: var(--bg);
}
</style>
3.利用SCSS变量+动态类样式切换:class="[‘header’,curTheme]"
3.1定义css变量
//variable.css
//默认主题颜色
$dark: #374151;
//鲜明色
$light:#ffffff;
$header-default-height:20%;
3.2导入scss文件
<style scoped lang="scss">
@import "src/assets/styles/variables";
</style>
3.3使用css变量构建不同类样式
<style scoped lang="scss">
@import "src/assets/styles/variables";
.light{background-color:$light;
}
.dark{background-color:$dark;
}
.header {display: flex;justify-content: space-between;align-items: center;color: white;padding: 0 20px;height: 7%;
}
</style>
3.4 设置切换逻辑
<script setup lang="ts">
const curTheme=ref("dark")
const toggleTheme=()=>{
curTheme.value=curTheme.value==="dark"?"light":"dark";
}
</script>
3.5绑定动态类样式
<template><el-header :class="['header',curTheme]"></el-header></template>
4.修改scss变量值
在 Vue 中,你可以通过直接修改 CSS 变量的值来实现主题切换。CSS 变量(也称为自定义属性)允许你在 CSS 中定义可以在整个文档或特定元素范围内重用的值。通过 JavaScript,你可以动态地改变这些变量的值,从而改变页面的样式。
以下是一个简单的例子,展示了如何在 Vue 组件中通过修改 CSS 变量的值来切换主题:
- 在 CSS/SCSS 中定义 CSS 变量:
首先,在你的全局样式文件(如 styles.scss
或直接在组件的 <style>
标签内)中定义 CSS 变量。
:root {--primary-color: #374151; // 默认主题颜色--background-color: #f0f0f0; // 默认背景颜色
}.dark-theme {--primary-color: #ffffff; // 深色主题颜色--background-color: #374151; // 深色背景颜色
}
注意:虽然 .dark-theme
类在这里被定义了,但我们稍后将通过 JavaScript 直接修改根元素的 CSS 变量,而不是切换类名。
- 在 Vue 组件中:
在你的 Vue 组件中,你可以通过 mounted
钩子、计算属性或方法来访问和修改这些 CSS 变量的值。
<template><div :class="[isDarkTheme ? 'dark-theme-indicator' : '']"><!-- 你的内容 --><button @click="toggleTheme">切换主题</button></div>
</template><script>
export default {data() {return {isDarkTheme: false, // 初始主题为浅色};},methods: {toggleTheme() {this.isDarkTheme = !this.isDarkTheme;this.updateThemeVariables();},updateThemeVariables() {const root = document.documentElement;root.style.setProperty('--primary-color', this.isDarkTheme ? '#ffffff' : '#374151');root.style.setProperty('--background-color', this.isDarkTheme ? '#374151' : '#f0f0f0');},},mounted() {// 初始化主题(可选)this.updateThemeVariables();},
};
</script><style scoped>
/* 你可以在这里添加一些基于 CSS 变量的样式 */
.dark-theme-indicator {/* 只是一个指示器,用于显示当前是深色主题 */border: 1px solid red; /* 仅为示例 */
}/* 使用 CSS 变量 */
body {background-color: var(--background-color);color: var(--primary-color);
}/* ... 其他样式 ... */
</style>
在这个例子中,toggleTheme
方法会切换 isDarkTheme
的值,并调用 updateThemeVariables
方法来更新 CSS 变量的值。updateThemeVariables
方法通过访问 document.documentElement
(即 <html>
元素)并设置其 style.setProperty
方法来更改 CSS 变量的值。
注意,虽然我们在组件中定义了 .dark-theme
类,但实际上并没有将其应用到任何元素上。这是因为我们直接通过 JavaScript 修改了 CSS 变量的值,而不是通过切换类名来改变样式。不过,你仍然可以保留这个类作为一个指示器或用于其他目的(比如添加一些仅在深色主题下显示的额外样式)。
另外,请注意,如果你的项目中使用了 SCSS,并且你希望在 SCSS 文件中使用这些变量,你需要确保在编译 SCSS 时这些变量已经被定义。由于 CSS 变量是在运行时通过 JavaScript 修改的,SCSS 编译时无法知道它们的最终值。因此,你通常会在全局样式表或组件的 <style>
标签中定义这些变量,并在 JavaScript 中动态地修改它们。
注意事项
有些时候明明导入scss,但确发现不起作用,还是找不到css变量!!!
考虑CSS 文件加载顺序问题,是真的先加载scss文件了吗?
如果你的 CSS 变量定义在一个后加载的 CSS 文件中,而你在一个先加载的 CSS 文件或 JavaScript 代码中尝试访问它,那么就会出现未定义的错误。确保定义变量的 CSS 文件在访问变量的文件之前被加载。
不妨定义一个全局的变量并在main.ts就导入(虚拟DOM生成前就导入)
相关文章:

Vue中动态样式绑定+CSS变量实现切换明暗主题功能——从入门到进阶
1.直接借助Vue的动态绑定样式绑定 Vue动态样式绑定 在Vue中,动态样式绑定是一种强大的功能,它允许开发者根据数据的变化动态地更新元素的样式。以下是对Vue动态样式绑定的详细知识梳理与详解: 一、基础知识 Vue的动态样式绑定主要通过v-b…...
vue3 video 播放rtmp视频?(360浏览器支持)
** 注意:目前只能在360浏览器播放rtmp视频** 谷歌浏览器不支持Flash Player的问题 试过上面这个方法,目前没能实现(没解决),如果有更好的解决方法,告诉我一下 需要下载版本较低的video.js版本库࿰…...

RK356x bsp 7 - PCF8563 RTC调试记录
文章目录 1、环境介绍2、目标3、PCF85634、dts配置5、内核配置6、测试验证 1、环境介绍 硬件:飞凌ok3568-c开发板 软件:原厂rk356x sdk 2、目标 开发板断电后仍正常计时。 3、PCF8563 PCF8563 是由 NXP Semiconductors 公司生产的低功耗 CMOS 实时…...
定义Shape:打造属于你的独特图形
自定义Shape:打造属于你的独特图形 在Android开发中,自定义图形绘制是一个非常重要的技能,尤其是在需要实现复杂UI或特定设计需求时。Android提供了android.graphics.drawable.shapes包,其中包含了一些基本的形状类,如RectShape、OvalShape等。然而,有时这些基本形状无法…...

JavaWeb(一) | 基本概念(web服务器、Tomcat、HTTP、Maven)、Servlet 简介
1. 基本概念 1.1、前言 web开发: web,网页的意思,www.baidu.com静态 web html,css提供给所有人看的数据始终不会发生变化! 动态 web 淘宝,几乎是所有的网站;提供给所有人看的数据始终会发生变化…...

python学opencv|读取图像(二十一)使用cv2.circle()绘制圆形进阶
【1】引言 前序已经掌握了使用cv2.circle()绘制圆形的基本操作,相关链接为: python学opencv|读取图像(二十)使用cv2.circle()绘制圆形-CSDN博客 由于圆形本身绘制起来比较简单,因此可以自由操作的空间也就大&#x…...

CLIP:连接文本与图像, 从自然语言监督中学习可迁移的视觉模型
CLIP:连接文本与图像, 从自然语言监督中学习可迁移的视觉模型 flyfish Learning Transferable Visual Models From Natural Language Supervision https://github.com/OpenAI/CLIP 摘要 CLIP Contrastive Language-Image Pre-Training Contrastive&…...
Linux 硬盘扩容 分区 挂载
Linux 硬盘扩容 分区 & 挂载 1. 添加分区 1.1. 查看新添加的硬盘 fdisk -l假设当前未挂载的盘符是/dev/sdb,后文中所有操作都按挂载/dev/sdb 操作 1.2. 分区管理 小硬盘 fdisk /dev/sdb大硬盘(2TB以上) gdisk /dev/sdb1.3. 编辑分…...
基于 Slf4j 和 AOP 的自动化方法执行时间日志记录方案
前言 其实这个需求很简单,但是这个需求又是项目中必不可少的,尤其对于性能调优这块,但是使用哪种方式更加方便呢,这就是本篇博文需要讨论的重点 系统时间 可以通过 System.currentTimeMillis() 或 System.nanoTime() 来实现。 …...

关于 K8s 的一些基础概念整理-补充【k8s系列之二】
〇、前言 本文继续整理下 K8s 的一些基础概念,作为前一篇概念汇总的补充。 前一篇博文链接:关于 K8s 的一些基础概念整理【k8s系列之一】_集群 master节点 控制节点 宿主机-CSDN博客 一、详情 1.1 Label Label 在 k8s 中是一个非常核心的概念…...

FPGA的DMA应用——pcileech
硬件通过pcie总线,访存本机的内存,并进行修改,可以进行很多操作。 学习视频:乱讲DMA及TLP 1-pcileech项目简介和自定义模块介绍_哔哩哔哩_bilibili vivado2024.1的下载文章链接和地址:AMD-Xilinx Vivado™ 2024.1 现…...
信息安全管理:运行管理checklist
运行管理checklist内容包括日常操作与维护管理、变更管理、备份与故障恢复、应急与业务连续性管理等内容。 一、日常操作与维护管理 ▼▼制度与流程 是否建立日常运行操作制度与流程?包括网络、主机、应用等方面的操作制度与流程? 是否明确相关部门和人…...

Linux系统之stat命令的基本使用
Linux系统之stat命令的基本使用 一、stat命令 介绍二、stat命令帮助2.1 查询帮助信息2.2 stat命令的帮助解释 三、stat命令的基本使用3.1 查询文件信息3.2 查看文件系统状态3.3 使用格式化输出3.4 以简洁形式打印信息 四、注意事项 一、stat命令 介绍 stat 命令用于显示文件或文…...

云手机+Facebook:让科技与娱乐完美结合
移动互联网时代,Facebook作为全球最大的社交媒体平台之一,早已成为企业、品牌和组织竞相角逐的营销阵地。而云手机的出现,则为Facebook营销注入了新的活力,其独特的优势让营销活动更加高效、精准且灵活。本文将深入探讨云手机在Fa…...

为什么要在PHY芯片和RJ45网口中间加网络变压器
在PHY芯片和RJ45网口之间加入网络变压器是出于以下几个重要的考虑: 1. 电气隔离:网络变压器提供了电气隔离功能,有效阻断了PHY芯片与RJ45之间直流分量的直接连接。这样可以防止可能的电源冲突,降低系统故障的风险,并保…...

LeetCode 19:删除链表的倒数第N 个结点
题目: 地址:https://leetcode.cn/problems/remove-nth-node-from-end-of-list/ 方法一: 方法二: 代码: package com.zy.leetcode.LeetCode_19;/*** Author: zy* Date: 2024-12-25-13:01* Description: 删除链表…...

RT-DETR融合[IJCV2024]LSKNet中的LSKBlock模块
RT-DETR使用教程: RT-DETR使用教程 RT-DETR改进汇总贴:RT-DETR更新汇总贴 《Large Selective Kernel Network for Remote Sensing Object Detection》 一、 模块介绍 论文链接:https://arxiv.org/pdf/2303.09030 代码链接:https:…...

C/C++ 数据结构与算法【树和森林】 树和森林 详细解析【日常学习,考研必备】带图+详细代码
一、树的存储结构 1)双亲表示法实现: 定义结构数组存放树的结点,每个结点含两个域: 数据域:存放结点本身信息。双亲域:指示本结点的双亲结点在数组中的位置。 特点:找双亲简单,找孩子难 C语…...
新浪微博大数据面试题及参考答案(数据开发和数据分析)
介绍一下你所掌握的计算机网络和操作系统相关知识 计算机网络:计算机网络是将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统。我掌握了网络协议…...

OpenHarmony怎么修改DPI密度值?RK3566鸿蒙开发板演示
本文介绍在开源鸿蒙OpenHarmony系统下,修改DPI密度值的方法,触觉智能Purple Pi OH鸿蒙开发板演示,搭载了瑞芯微RK3566四核处理器,Laval鸿蒙社区推荐开发板,已适配全新开源鸿蒙OpenHarmony5.0 Release系统,适…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...

Prompt Tuning、P-Tuning、Prefix Tuning的区别
一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql
智慧工地管理云平台系统,智慧工地全套源码,java版智慧工地源码,支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求,提供“平台网络终端”的整体解决方案,提供劳务管理、视频管理、智能监测、绿色施工、安全管…...
第25节 Node.js 断言测试
Node.js的assert模块主要用于编写程序的单元测试时使用,通过断言可以提早发现和排查出错误。 稳定性: 5 - 锁定 这个模块可用于应用的单元测试,通过 require(assert) 可以使用这个模块。 assert.fail(actual, expected, message, operator) 使用参数…...
spring:实例工厂方法获取bean
spring处理使用静态工厂方法获取bean实例,也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下: 定义实例工厂类(Java代码),定义实例工厂(xml),定义调用实例工厂ÿ…...
【AI学习】三、AI算法中的向量
在人工智能(AI)算法中,向量(Vector)是一种将现实世界中的数据(如图像、文本、音频等)转化为计算机可处理的数值型特征表示的工具。它是连接人类认知(如语义、视觉特征)与…...

SpringCloudGateway 自定义局部过滤器
场景: 将所有请求转化为同一路径请求(方便穿网配置)在请求头内标识原来路径,然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...
LRU 缓存机制详解与实现(Java版) + 力扣解决
📌 LRU 缓存机制详解与实现(Java版) 一、📖 问题背景 在日常开发中,我们经常会使用 缓存(Cache) 来提升性能。但由于内存有限,缓存不可能无限增长,于是需要策略决定&am…...
SpringAI实战:ChatModel智能对话全解
一、引言:Spring AI 与 Chat Model 的核心价值 🚀 在 Java 生态中集成大模型能力,Spring AI 提供了高效的解决方案 🤖。其中 Chat Model 作为核心交互组件,通过标准化接口简化了与大语言模型(LLM࿰…...

jdbc查询mysql数据库时,出现id顺序错误的情况
我在repository中的查询语句如下所示,即传入一个List<intager>的数据,返回这些id的问题列表。但是由于数据库查询时ID列表的顺序与预期不一致,会导致返回的id是从小到大排列的,但我不希望这样。 Query("SELECT NEW com…...