vue 中绑定样式 【style样式绑定】
style样式绑定
在 Vue 中,style 的绑定与 class 类似,也是通过 v-bind:style(或简写 :style)实现的,允许你动态地控制内联样式。Vue 对 style 做了非常智能的处理,支持对象、数组、字符串等多种语法,还能自动添加浏览器前缀。
✅ 基础语法
绑定对象
<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>data() {return {activeColor: 'red',fontSize: 16}
}
Vue 会将对象自动转换为内联样式字符串:
style="color: red; font-size: 16px;"
绑定数组
<div :style="[baseStyles, overridingStyles]"></div>data() {return {baseStyles: {color: 'blue',fontSize: '14px'},overridingStyles: {fontSize: '18px',fontWeight: 'bold'}}
}
数组中的后一个对象会覆盖前一个对象中相同的属性。
动态计算样式(推荐)
<template><div :style="styleObject">Box</div>
</template><script>
export default {data() {return {size: 20,color: 'green'}},computed: {styleObject() {return {width: this.size + 'px',height: this.size + 'px',backgroundColor: this.color}}}
}
</script>
🎯 高级特性
✅ 自动加前缀
Vue 会自动为某些需要前缀的 CSS 属性添加前缀,比如 transform、transition 等:
style: {transform: 'rotate(30deg)'
}
会生成:
style="-webkit-transform: rotate(30deg); transform: rotate(30deg);"
✅ 使用变量控制单位(像素、百分比等)
<div :style="{ marginTop: margin + 'px', width: percent + '%' }"></div>
✅ 多条件组合写法
<div:style="[isError ? errorStyle : null,isSuccess && successStyle,commonStyle]"
></div>
🧠 小技巧:结合 class 和 style 使用
<div :class="{ active: isActive }" :style="{ color: isActive ? 'red' : 'gray' }"></div>
这样可以用 class 控制结构样式,用 style 控制微调、动态样式。
🚫 注意事项
- Vue 的 style 绑定不会影响外部样式表(它只控制内联样式);
- 样式对象区分大小写,建议使用 camelCase(如 fontSize)而非 font-size;
- 不支持绑定到 style 标签(只能用于元素的 style 属性);
- 有些 CSS 属性需要特殊处理(如 !important 无法直接加)。
如果你需要动态添加 !important,只能用字符串拼接:
<div :style="'color: red !important;'"></div>
🔚 总结对比
绑定方式 | 数据类型 | 特点 |
---|---|---|
字符串 | ‘color: red;’ | 简单直接,功能有限 |
对象 | { color: ‘red’ } | 响应式强、推荐使用 |
数组 | [baseStyle, override] | 支持样式叠加与条件合并 |
🎯 本质理解::style 是动态内联样式绑定
<div :style="{ color: 'red', fontSize: '16px' }"></div>
Vue 做了什么?
- 你传给 :style 的值,可以是对象、数组或字符串;
- Vue 内部会根据不同类型,格式化为字符串,并设置为元素的 style 属性;
- Vue 会在数据变化时自动更新样式(依赖响应式系统)。
🔍 数据类型详解
✅ 对象(推荐)
:style="{ backgroundColor: bgColor }"
- 适用于大多数动态样式控制。
- 属性使用 camelCase,而不是 kebab-case。
小细节:
{ ‘font-size’: ‘14px’ } // ❌ 不推荐
{ fontSize: ‘14px’ } // ✅ 推荐
✅ 数组(叠加多个样式)
:style="[baseStyle, themeStyle]"
- 后面的样式会覆盖前面的;
- Vue 内部会遍历每个对象,合并到最终的 style 中。
✅ 字符串(不推荐)
:style="'color: red; font-size: 12px;'"
- 无法做响应式控制;
- 无法自动添加前缀;
- 仅适合快速原型或极简静态样式。
🔄 响应式原理
:style 与 Vue 的响应式系统完全集成。只要绑定的样式数据是响应式的,Vue 就会在依赖变更后:
- 重新生成 style 字符串;
- 对比新旧样式;
- 精确更新 DOM 的内联样式。
例如:
data() {return { color: 'blue' }
}
当 this.color = ‘red’ 时,对应元素的 style.color 也会实时更新。
🌀 自动前缀处理
Vue 会自动为需要添加前缀的属性加上前缀,例如:
:style="{ transform: 'rotate(30deg)' }"
Vue 会生成:
style="-webkit-transform: rotate(30deg); transform: rotate(30deg);"
前缀支持的平台包括:
- transform
- transition
- animation
- flex
- 等浏览器敏感属性
🧠 高级使用技巧
✅ 使用计算属性组织样式逻辑
computed: {cardStyle() {return {backgroundColor: this.isDark ? '#333' : '#fff',color: this.isDark ? '#fff' : '#000'}}
}
然后:
<div :style="cardStyle"></div>
**优势:**逻辑清晰、模板干净、可复用。
✅ 条件样式动态拼接
<div :style="[{ color: isError ? 'red' : 'black' },isLarge && { fontSize: '24px' }
]"></div>
逻辑表达式 + 条件对象结合,适用于多个样式控制。
✅ 和 class 结合使用
<div :class="{ active: isActive }" :style="{ backgroundColor: bg }"></div>
- class:用于结构/状态类(推荐控制布局、结构);
- style:用于动态颜色、大小、位置(推荐控制外观、视觉)。
🚫 常见坑和注意事项
问题 | 原因 | 解决方式 |
---|---|---|
属性写错大小写 | CSS 用 camelCase | background-color 要写作 backgroundColor |
单位漏写 | Vue 不自动补单位 | 自己拼接单位:fontSize: size + ‘px’ |
想要 !important | Vue 不支持对象中加 | 必须用字符串写法:style=“color: red !important;” |
样式失效 | 和外部类名冲突或被覆盖 | 检查优先级或用类样式控制更合适的部分 |
🧪 实例演练
<template><div :style="boxStyle" :class="{ big: isBig }">Hello Box</div><button @click="toggle">切换大小</button>
</template><script>
export default {data() {return {isBig: false}},computed: {boxStyle() {return {backgroundColor: this.isBig ? 'skyblue' : 'lightgray',width: this.isBig ? '300px' : '150px',height: '100px',transition: 'all 0.3s ease'}}},methods: {toggle() {this.isBig = !this.isBig}}
}
</script><style>
.big {border: 3px solid red;
}
</style>
✅ 总结
功能 | 推荐语法 | 用途 |
---|---|---|
简单样式绑定 | 对象语法 {} | 常规样式 |
多样式组合 | 数组语法 [] | 条件样式 |
更复杂逻辑 | 计算属性 + 对象 | 高可读性 |
与类名配合使用 | :class + :style | 结构 + 外观 |
自动前缀 | Vue 内部处理 | 跨浏览器兼容 |
相关文章:
vue 中绑定样式 【style样式绑定】
style样式绑定 在 Vue 中,style 的绑定与 class 类似,也是通过 v-bind:style(或简写 :style)实现的,允许你动态地控制内联样式。Vue 对 style 做了非常智能的处理,支持对象、数组、字符串等多种语法&#…...
印刷业直角坐标型码垛机器人系统设计与应用研究
摘要 随着印刷行业自动化水平的提升,本文针对传统人工码垛存在的效率低、标准化程度不足等问题,提出基于直角坐标系的专用码垛机器人解决方案。重点阐述机械臂结构设计、运动控制系统及智能抓取装置三大核心模块,通过实际应用验证系统在速度、…...

Mysql存储过程(附案例)
文章目录 存储过程概述1、基本语法2、变量①、系统变量②、用户自定义变量③、局部变量 3、流程控制语句①、if语句②、参数③、case语句④、while语句⑤、repeat语句⑥、loop语句⑦、cursor游标⑧、handler 4、存储函数 存储过程概述 存储过程是事先经过编译并存储在数据…...

【Web应用】Vue 项目前端项目文件夹和文件介绍
文章目录 ⭐前言⭐一、文件夹介绍🌟1、.idea🌟2、bin🌟3、build🌟4、node_modules🌟5、public🌟6、src ⭐二、文件介绍🌟1、.editorconfig🌟2、.env.development、.env.production、…...

Stratix 10 FPGA DDR4 选型
文章目录 前言DDR3 和 DDR4 的区别Micron 8Gb DDR4 规格书详解Micron 8Gb DDR4 编码规则ConfigurationDDR4 寻址原理 Speed Grade内存的频率MT/s 与 MHz:更好的内存速度衡量指标为什么 DDR4 的核心频率与 I/O 总线频率的比例是 1:4 呢? 带宽 Altera FPGA…...
Rust 输出到命令行
Rust 输出到命令行 引言 Rust 是一门系统编程语言,以其高性能、内存安全、并发支持和零成本抽象等特性而闻名。在开发过程中,将 Rust 程序的输出传递到命令行是常见的需求。本文将详细介绍 Rust 输出到命令行的多种方法,帮助读者掌握这一技…...
费曼技巧及提高计划
费曼技巧及提高计划 一、什么是费曼技巧? 费曼技巧(Feynman Technique)由诺贝尔物理学奖得主理查德费曼提出,是一种通过“以教代学”来彻底理解复杂概念的学习方法。其核心逻辑是: “如果你不能简单解释一件事&#x…...
扩展:React 项目执行 yarn eject 后的 config 目录结构详解
扩展:React 项目执行 yarn eject 后的 config 目录结构详解 什么是 yarn eject?React 项目执行 yarn eject 后的 config 目录结构详解📁 config 目录结构各文件作用详解env.jsgetHttpsConfig.jsmodules.jspaths.jswebpack.config.jswebpackDe…...

CMU-15445(4)——PROJECT#1-BufferPoolManager-Task#2
PROJECT#1-BufferPoolManager Task #2 - Disk Scheduler 在前一节我实现了 TASK1 并通过了测试,在本节中,我将逐步实现 TASK2。 如上图,Page Table(页表)通过哈希表实现,用于跟踪当前存在于内存中的页&am…...

百度智能云千帆携手联想,共创MCP生态宇宙
5月7日,2025联想创新科技大会(Tech World)在上海世博中心举行,本届大会以“让AI成为创新生产力”为主题。会上,联想集团董事长兼CEO杨元庆展示了包括覆盖全场景的超级智能体矩阵,包括个人超级智能体、企业超…...
Python 中的 typing.ClassVar 详解
一、ClassVar 的定义和基本用途 ClassVar 是 typing 模块中提供的一种特殊类型,用于在类型注解中标记类变量(静态变量)。根据官方文档,使用 ClassVar[…] 注释的属性表示该属性只在类层面使用,不应在实例上赋值 例如&…...

【动态导通电阻】GaN HEMT动态导通电阻的精确测量
2023 年 7 月,瑞士洛桑联邦理工学院的 Hongkeng Zhu 和 Elison Matioli 在《IEEE Transactions on Power Electronics》期刊发表了题为《Accurate Measurement of Dynamic ON-Resistance in GaN Transistors at Steady-State》的文章,基于提出的稳态测量方法,研究了氮化镓(…...

java 使用zxing生成条形码(可自定义文字位置、边框样式)
最新工作中遇到生成条形码的需求,经过一番摸索之后找到了zxing这个工具类,实现效果如下: 首先引入依赖: <!-- 条形码生成器 --><dependency><groupId>com.google.zxing</groupId><artifactId&g…...

day19-线性表(顺序表)(链表I)
一、补充 安装软件命令: sudo apt-get install (软件名) 安装格式化对齐:sudo apt-get install clang-format内存泄漏检测工具: sudo apt-get install valgrind 编译后,使用命令 valgrind ./a.out 即可看内存是…...

CSS- 2.1 实战之图文混排、表格、表单、学校官网一级导航栏
本系列可作为前端学习系列的笔记,代码的运行环境是在HBuilder中,小编会将代码复制下来,大家复制下来就可以练习了,方便大家学习。 HTML系列文章 已经收录在前端专栏,有需要的宝宝们可以点击前端专栏查看! 点…...
Armijo rule
非精线搜索步长规则Armijo规则&Goldstein规则&Wolfe规则_armijo rule-CSDN博客 [原创]用“人话”解释不精确线搜索中的Armijo-Goldstein准则及Wolfe-Powell准则 – 编码无悔 / Intent & Focused...

从零搭建AI工作站:Gemma3大模型本地部署+WebUI配置全套方案
文章目录 前言1. 安装Ollama2.Gemma3模型安装与运行3. 安装Open WebUI图形化界面3.1 Open WebUI安装运行3.2 添加模型3.3 多模态测试 4. 安装内网穿透工具5. 配置固定公网地址总结 前言 如今各家的AI大模型厮杀得如火如荼,每天都有新的突破。今天我要给大家安利一款…...

贝叶斯优化Transformer融合支持向量机多变量时间序列预测,Matlab实现
贝叶斯优化Transformer融合支持向量机多变量时间序列预测,Matlab实现 目录 贝叶斯优化Transformer融合支持向量机多变量时间序列预测,Matlab实现效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.BO-TransformerSVM多变量时间序列预测,…...
执行apt-get update 报错ModuleNotFoundError: No module named ‘apt_pkg‘的解决方案汇总
Ubuntu版本ubuntu18.04 报错内容: //执行apt-get upgrade报错: Traceback :File “/usr/lib/cnf-update-db”, line 8, in <module>from CommandNotFound.db.creator import DbcreatorFile “/usr/lib/python3/dist-packages/CommandNotFound/db…...
maven中relativepath标签的含义及使用方法
在Maven中,<relativePath>标签用于指定子模块的父POM文件的相对路径,以便在构建时优先从本地项目结构中查找父项目,而非直接从仓库获取。以下是其含义和使用方法的详细说明: 含义 作用:在子模块的<parent>元素中,<relativePath>定义了父POM文件相对于当…...

C++_STL_map与set
1. 关联式容器 在初阶阶段,我们已经接触过STL中的部分容器,比如:vector、list、deque、 forward_list(C11)等,这些容器统称为序列式容器,因为其底层为线性序列的数据结构,里面 存储的是元素本身。那什么是…...

项目依赖版本修改
React项目 因UI库无法兼容React19版本,故此降低React版本至18.x (为什么不升级UI库版本,因为没有最新版,而且找不到好的替代品) package.json 先修改package.json文件中你想修改的依赖版本号 "dependencies": { - "react": "^19.1.0", - "…...

蚁群算法赋能生鲜配送:MATLAB 实现多约束路径优化
在生鲜农产品配送中,如何平衡运输效率与成本控制始终是行业难题。本文聚焦多目标路径优化,通过 MATLAB 实现蚁群算法,解决包含载重限制、时间窗约束、冷藏货损成本的复杂配送问题。代码完整复现了从数据生成到路径优化的全流程,助…...

机器学习与人工智能:NLP分词与文本相似度分析
自然语言处理 你有没有想过,生成式 AI 工具或大型语言模型背后究竟发生了什么?自然语言处理(NLP)是这些工具的核心,它使计算机能够理解人类语言。换句话说,NLP 是连接人类交流和机器(如计算机&…...

记录一下seata后端数据库由mariadb10切换到mysql8遇到的SQLException问题
文章目录 前言一、问题记录二、参考帖子三、记录store.db.driverClassName 前言 记录一下seata后端数据库由mariadb10切换到mysql8遇到的SQLException问题。 一、问题记录 17:39:23.709 ERROR --- [ionPool-Create-1134013833] com.alibaba.druid.pool.DruidDataSource : …...

CUDA学习笔记
CUDA入门笔记 总览 CUDA是NVIDIA公司对其GPU产品提供的一个编程模型,在2006年提出,近年随着深度学习的广泛应用,CUDA已成为针对加速深度学习算法的并行计算工具。 以下是维基百科的定义:一种专有的并行计算平台和应用程序编程接…...
Python爬虫实战:研究JavaScript压缩方法实现逆向解密
一、引言 在数字化信息爆炸的时代,网络数据已成为驱动各行业发展的核心资产。Python 凭借其丰富的库生态和简洁的语法,成为网络爬虫开发的首选语言。然而,随着互联网安全防护机制的不断升级,网站普遍采用 JavaScript 压缩与混淆技术保护其核心逻辑和数据传输,这使得传统爬…...
【Linux】Shell脚本中向文件中写日志,以及日志文件大小、数量管理
1、写日志 shell脚本中使用echo命令,将字符串输入到文件中 覆盖写入:echo “Hello, World!” > laoer.log ,如果文件不存在,则会创建文件追加写入:echo “Hello, World!” >> laoer.log转移字符:echo -e “Name:\tlaoer\nAge:\t18” > laoer.log,\t制表符 …...

c++ 类的语法3
测试下默认构造函数。demo1: void testClass3() {class Demo { // 没显示提供默认构造函数,会有默认构造函数。public:int x; // 普通成员变量,可默认构造};Demo demo1;//cout << "demo1.x: " << demo1.x << en…...
Rust 学习笔记:关于 String 的练习题
Rust 学习笔记:关于 String 的练习题 Rust 学习笔记:关于 String 的练习题选出描述正确的那一个。该程序最多可能发生多少次堆的内存分配?哪种说法最能解释为什么 Rust 不允许字符串索引?哪种说法最能描述字符串切片 &str 和字…...