vue.js学习笔记之绑定style样式和class列表


Posted in Javascript onOctober 31, 2016

数据绑定一个常见需求是操作元素的 class 列表和它的内联样式。因为它们都是 attribute,我们可以用 v-bind 处理它们:只需要计算出表达式最终的字符串。不过,字符串拼接麻烦又易错。因此,在 v-bind 用于 class 和 style 时,Vue.js 专门增强了它。表达式的结果类型除了字符串之外,还可以是对象或数组。

一.绑定Class属性。

绑定数据用v-bind:命令,简写成:

语法:<div v-bind:class="{ active: isActive }"></div>。class后面的双引号里接受一个对象字面量/对象引用/数组作为参数,

这里,{active: isActive}是对象参数,active是class名,isActive是一个布尔值。下面是一个例子:

绑定对象字面量

html:

<div id="classBind">
<span :class="{warning:isWarning,safe:isSafe}" v-on:click="toggle">
状态:{{alert}}{{isSafe}}
</span>
</div>
//js
var app11=new Vue({
el:'#classBind',
data:{
isWarning:true,
alertList:['红色警报','警报解除'],
alert:''
},
computed:{
isSafe:function(){
return !this.isWarning;
}
},
methods:{
toggle:function(){
this.isWarning=!this.isWarning;
this.alert= this.isWarning?this.alertList[0]:this.alertList[1];
}
}
});

css:

.warning{
color:#f24;
}
.safe{
color:#42b983;
}

当点击状态文字时,可以切换后面的文字和颜色

//状态:警报解除true

//状态:红色警报false

绑定对象引用

这里绑定的对象可以写到Vue实例的data里面,而在class="classObj ",双引号中的class是对Vue实例中classObj对象的引用。classObj可以放在data中或者computed中,如果在computed中,则classObj所对应的函数必须返回一个对象如下:

js:

var app11=new Vue({
el:'#classBind',
data:{
isWarning:true,
alertList:['红色警报','警报解除'],
alert:''
},
computed: {
isSafe: function () {
return !this.isWarning;
},
classObj:function(){
return {
warning: this.isWarning,
safe:this.isSafe
}
}
},
methods:{
toggle:function(){
this.isWarning=!this.isWarning;
this.alert= this.isWarning?this.alertList[0]:this.alertList[1];
}
}
});

绑定数组

html:

<div v-bind:class="classArray" @click="removeClass()">去掉class</div>

js

data: {
classArray:["big",'red']
}
methods:{
removeClass:function(){
this.classArray.pop();
}
}

css:

.big{
font-size:2rem;
}
.red{
color:red; 
}

效果,点击去掉class,会调用removeClass函数,去掉classArray数组的最后一项,第一次,去掉'red',字体颜色由红变黑,再点,去掉'big',字体变小。

二、绑定内联style

此时此刻,我一边看着本页旁边的那个Vue api文档学,一边到这里卖,装逼的感觉真爽o(^?^)o

html

<div id="styleBind">
<span :style="{color:theColor,fontSize:theSize+'px'}" @click="bigger">styleBind</span>
</div>

css

这个不需要css。。。

js

var app12=new Vue({
el:'#styleBind',
data:{
theColor:'red',
theSize:14
},
methods:{
bigger:function(){
this.theSize+=2;
}
}
});

除了传入对象字面量以外,也可以传入对象引用和数组给V-bind:style

以上所述是小编给大家介绍的vue.js学习笔记之绑定style和class,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript 操作Word和Excel的实现代码
Oct 26 Javascript
Js 随机数产生6位数字
May 13 Javascript
JS函数this的用法实例分析
Feb 05 Javascript
angularjs学习笔记之双向数据绑定
Sep 26 Javascript
javascript创建对象的几种模式介绍
May 06 Javascript
jQuery实现贪吃蛇小游戏(附源码下载)
Mar 04 Javascript
深入浅出webpack教程系列_安装与基本打包用法和命令参数详解
Sep 10 Javascript
Vuejs 单文件组件实例详解
Feb 09 Javascript
swiper在angularjs中使用循环轮播失效的解决方法
Sep 27 Javascript
解决vue自定义全局消息框组件问题
Nov 22 Javascript
JQuery常用简单动画操作方法回顾与总结
Dec 07 jQuery
vue+element 实现商城主题开发的示例代码
Mar 26 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
Oct 31 #Javascript
jQuery grep()方法详解及实例代码
Oct 30 #Javascript
webix+springmvc session超时跳转登录页面
Oct 30 #Javascript
js获取时间函数及扩展函数的方法
Oct 30 #Javascript
jquery ajax后台返回list,前台用jquery遍历list的实现
Oct 30 #Javascript
浅谈JS函数定义方式的区别
Oct 30 #Javascript
基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询
Oct 30 #Javascript
You might like
PHP数组 为文章加关键字连接 文章内容自动加链接
2011/12/29 PHP
php处理文件的小例子(解压缩,删除目录)
2013/02/03 PHP
php上传apk后自动提取apk包信息的使用(示例下载)
2013/04/26 PHP
php cli模式学习(PHP命令行模式)
2013/06/03 PHP
使用phpQuery采集网页的方法
2013/11/13 PHP
windows7下php开发环境搭建图文教程
2015/01/06 PHP
PHPExcel在linux环境下导出报500错误的解决方法
2017/01/26 PHP
PHP中散列密码的安全性分析
2019/07/26 PHP
List Information About the Binary Files Used by an Application
2007/06/18 Javascript
javascript读取xml实现javascript分页
2013/12/13 Javascript
javascript动态创建链接的方法
2015/05/13 Javascript
Javascript控制div属性动态变化实例分析
2015/10/08 Javascript
js实现上传文件添加和删除文件选择框
2016/10/24 Javascript
基于JavaScript实现下拉列表左右移动代码
2017/02/07 Javascript
浅谈js中用$(#ID)来作为选择器的问题(id重复的时候)
2017/02/14 Javascript
详解webpack提取第三方库的正确姿势
2017/12/22 Javascript
从vue基础开始创建一个简单的增删改查的实例代码(推荐)
2018/02/11 Javascript
原生JS实现旋转轮播图+文字内容切换效果【附源码】
2018/09/29 Javascript
React Component存在的几种形式详解
2018/11/06 Javascript
javascript设计模式 ? 代理模式原理与用法实例分析
2020/04/16 Javascript
微信小程序实现底部弹出框
2020/11/18 Javascript
Python中super函数的用法
2017/11/17 Python
Python解析Excle文件中的数据方法
2018/10/23 Python
pandas 将索引值相加的方法
2018/11/15 Python
windows下python虚拟环境virtualenv安装和使用详解
2019/07/16 Python
pygame库实现移动底座弹球小游戏
2020/04/14 Python
Python日志处理模块logging用法解析
2020/05/19 Python
SmartBuyGlasses美国官网:太阳眼镜和眼镜
2017/08/20 全球购物
苹果台湾官网:Apple台湾
2019/01/05 全球购物
介绍一下write命令
2014/08/10 面试题
摄影实习自我鉴定
2013/09/20 职场文书
中专毕业生的自我鉴定
2013/12/01 职场文书
出国导师推荐信
2014/01/16 职场文书
竞聘演讲稿怎么写
2014/08/28 职场文书
党的生日演讲稿
2014/09/10 职场文书
Redis基本数据类型Set常用操作命令
2022/06/01 Redis