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

Vue基础知识-Vue中:class与:style动态绑定样式

完整源码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="../js/vue.js"></script>
</head>
<body><div id="root"> <!--class字符串写法--><div class="basic" :class="str">你好</div><br><br><!--class数组写法--><div class="basic" :class="classArr">你好</div><br><br><input type="button" @click="bigFont"  value='字体变大'></button><br><br><!--class对象写法--><div class="basic" :class="classObj">你好</div><br><br><input type="button" @click="backgroundColor"  value='背景变色'></button><br><br><!--style对象写法,数组写法比较少这里不介绍--><div class="basic" :style="styleObj">你好</div><br><br><input type="button" @click="changeFontSize"  :value='isSmall?"字体变大":"字体变小"' /></div>
</body><script>const vm = new Vue({el:'#root',data() {return {str:'smallFont',classArr:[],classObj:{backgroundColor:false //false表示不使用该class},styleObj:{fontSize : ''},isSmall:false}},methods: {bigFont(){this.classArr.push('bigFont')},backgroundColor(e){this.classObj.backgroundColor = !this.classObj.backgroundColorthis.classObj.backgroundColor?e.target.value = '恢复原色':e.target.value = '背景变色'},changeFontSize(){this.isSmall = !this.isSmallif(this.isSmall) this.styleObj.fontSize = '15px'else this.styleObj.fontSize = '30px'}}})</script><style>.basic{font-size: 30px;color: red;}.smallFont{font-size: 15px;}.bigFont{font-size: 50px;}.backgroundColor{background-color: aqua;}</style>
</html>

代码解析

1. 动态绑定 class 的三种方式

(1)字符串写法
<div class="basic" :class="str">你好</div>
  • 特点:通过字符串指定类名,适用于类名不确定的场景
  • 原理:str的值为smallFont,初始时会在basic类基础上添加smallFont
(2)数组写法
<div class="basic" :class="classArr">你好</div>
<input type="button" @click="bigFont" value='字体变大'>
  • 特点:通过数组存储多个类名,适用于需要动态添加类名的场景
  • 原理:点击按钮时,调用bigFont方法向classArr数组中添加bigFont
(3)对象写法
<div class="basic" :class="classObj">你好</div>
<input type="button" @click="backgroundColor" value='背景变色'>
  • 特点:通过对象的键值对(键为类名,值为布尔值)控制类是否生效,适用于样式切换场景
  • 原理:点击按钮时切换classObj.backgroundColor的值(true/false),控制backgroundColor类是否生效

2. 动态绑定 style 的方式

<div class="basic" :style="styleObj">你好</div>
<input type="button" @click="changeFontSize" :value='isSmall?"字体变大":"字体变小"' />
  • 特点:通过对象直接绑定行内样式,适用于需要动态设置具体样式值的场景
  • 原理:点击按钮时切换isSmall的值,根据其值设置styleObj.fontSize的具体大小

3. 小结

  • :class:style是 Vue 的指令,用于动态绑定样式
  • 静态类(如basic)和动态类可以同时存在
  • 样式切换的核心是通过修改数据(data 中的属性)来驱动视图变化
  • class 绑定适用于预定义的 CSS 类,style 绑定适用于需要动态计算的样式值
http://www.xdnf.cn/news/1426321.html

相关文章:

  • 【计算岗位解析:从代码到产品,这些角色如何“造”出数字世界?】
  • 威科夫与高频因子
  • (Redis)Redis 分布式锁及改进策略详解
  • Spring 控制器参数注解
  • VBA开发者的福音:让代码效率暴涨300%的终极数据结构选择指南
  • 基于单片机智能空调/温度控制系统
  • 力扣404 代码随想录Day15 第三题
  • GitHub每日最火火火项目(9.1)
  • Java类和对象(下)
  • 二维元胞自动机:从生命游戏到自复制系统的计算宇宙
  • pprint:美观打印数据结构
  • 基于单片机十六路抢答器系统Proteus仿真(含全部资料)
  • Qt::Q_INIT_RESOURCE用法
  • 前端性能优化实战:如何高效管理和加载图片、字体、脚本资源
  • 在 Qt 中:QString 好,还是 std::string 好?
  • 零售行业的 AI 革命:从用户画像到智能供应链,如何让 “精准营销” 不再是口号?
  • 响应式编程框架Reactor【9】
  • 2.充分条件与必要条件
  • 基本问题解决--舵机
  • 手把手教你搭建 UDP 多人聊天室(附完整源码)
  • 10.《基础知识探秘:DHCP地址分配员》
  • 打工人日报#20250901
  • nCode 后处理常见问题汇总
  • C++精选面试题集合(100份大厂面经提取的200+道真题)
  • 实现自己的AI视频监控系统-第三章-信息的推送与共享2
  • 【自记录】Ubuntu20.04下Python自编译
  • docker-nacos-v3
  • 在飞牛构建私有化协作环境GodoOS:集成文档、即时通讯、白板与思维导图!
  • 用只能以关键字指定和只能按位置传入的参数来设计清晰的接口(Effective Python 第25条)
  • Web知识的总结