vue元素样式实现动态改变方法介绍
1 前言
在vue
项目中,很多场景要求我们动态改变元素的样式,比如按钮由不可点击到可以点击样式改变,这种情况下,我们通常根据vue
框架提供的动态绑定v-bind
来操作元素的class列表贺内联样式来达到动态设置元素样式的效果;
2 动态改变样式的方法
2.1 操作元素class列表
我们通过vue内置的:class
(v-bind:class
)来动态操作元素的class;如下所示:
<div :class="{ class-a: isActive }"></div> <script> data() { return { isActive: true } } <script> <style scoped> .class-a { ... } </style>
其中class-a
代表样式表style中的一个样式对象,isActive
时控制样式是否生效的变量,若isActive
为true,则代表class-a
样式生效,此时class-a
回家加载到div元素的样式列表中,isActive
为false则不生效,不会将class加载到div元素额样式列表中。
我们用实例来演示一下,实例实现的效果时效果图如下:
实例代码如下:
<template> <div :class="{ 'dark-theme': isActive }"> <title-bar :title="title" @goBack="goback"></title-bar> <div> <div class="sty-item"> <label>改变页面主题色:</label> <TButton @clickhandle="changeTheme" /> </div> </div> </div> </template> <script> import TitleBar from "@/components/TitleBar"; import TButton from "@/components/TButton"; export default { name: "", // 动态控制vue 页面元素样式 components: { TitleBar, TButton }, data() { return { isActive: false, // class是否生效 title: "动态样式", }; }, methods: { changeTheme() { if (this.isActive) { this.isActive = false; } else { this.isActive = true; } }, goback() { // } } }; </script> <style lang="scss" scoped> .page-body1 { background-color: rgb(21, 126, 29); margin: 10px 15px; } .dark-theme { background-color: rgb(41, 46, 42); color: azure; } </style>
除此之外,还可以直接使用对象变量来控制class的变化,并且使用动态class同时,也能同时设置普通杨式,代码如下所示:
<div class="static" :class="classObj" ></div> <script> data() { return { classObj: { 'class-a': true, 'class-b': false } } } <script> <style scoped> .static { ... } .class-a { ... } .class-b { ... } </style>
以上代码最后作用于div上的class列表为:[static,class-a]
2.2 操作元素内联样式
与上面操作元素class列表原利相同,我们通过vue内置的:style
(v-bind:style
)来动态操作元素的内联样式;和class不同的是,内联样式本身就是一个对象,这就意味着style可以更为灵活的变化,如下所示:
<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div> <script> data() { return { activeColor: 'red', fontSize: 30 } } <script>
也可以写作对象形式,以上代码等同于:
<div :style="styleObject"></div> <script> data() { return { styleObject: { activeColor: 'red', fontSize: 30 } } } <script>
我们用实例来演示一下,实例实现的效果时效果图如下:
实例代码如下:
<template> <div> <title-bar :title="title" @goBack="goback"></title-bar> <div> <div class="sty-item"> <label>改变按钮样式:</label> <button class="btn" :style="dynamicStyle" @click="btnColorChange"> 我是按钮 </button> </div> </div> </div> </template> <script> import TitleBar from "@/components/TitleBar"; export default { name: "", // 动态控制vue 页面元素样式 components: { TitleBar }, data() { return { title: "动态样式", dynamicStyle: {}, //内联样式控制 brightStyle: { //亮色 background: "linear-gradient(45deg, rgb(225, 194, 137), rgb(213, 208, 156))", color: "#fff" }, darkStyle: { //暗色 background: "linear-gradient(45deg, rgb(143, 255, 109), rgb(208, 252, 172))", color: "#000" } }; }, methods: { btnColorChange() { console.log(this.dynamicStyle); if (this.compareObj(this.dynamicStyle, this.darkStyle)) { this.dynamicStyle = this.brightStyle; } else { this.dynamicStyle = this.darkStyle; console.log(this.dynamicStyle); } }, compareObj(a, b) { return JSON.stringify(a) == JSON.stringify(b) ? true : false; }, goback() { // } } }; </script> <style lang="scss" scoped> .btn { width: 125px; height: 45px; font-size: 20px; border: none; border-radius: 6px; } .sty-item { padding: 30px; text-align: left; label { margin: 20px 0px; display: block; } } </style>
可以看到对内联样式style
的控制可以更加灵活。
3 小结
动态操作页面样式的用法可以更为丰富多样,我们这里对基本用法做个简单介绍;更为复杂的用法可以结合前面讲的组件动态传值来控制子组件的样式,可实现千变万化的效果。
到此这篇关于vue元素样式实现动态改变方法介绍的文章就介绍到这了,更多相关vue元素样式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解如何将 Vue-cli 改造成支持多页面的 history 模式
本篇文章主要介绍了详解如何将 Vue-cli 改造成支持多页面的 history 模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11vue3中通过遍历传入组件名称动态创建多个component 组件
这篇文章主要介绍了vue3中通过遍历传入组件名称动态创建多个component 组件,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-03-03Vue响应式原理Observer、Dep、Watcher理解
这篇文章主要介绍了Vue响应式原理-理解Observer、Dep、Watcher,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-06-06
最新评论