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 相关文章推荐
延时重复执行函数 lLoopRun.js
May 08 Javascript
JavaScipt基本教程之前言
Jan 16 Javascript
JavaScript 密码强度判断代码
Sep 05 Javascript
javascript学习笔记(十) js对象 继承
Jun 19 Javascript
使用js+jquery实现无限极联动
May 23 Javascript
JS结合bootstrap实现基本的增删改查功能
Jul 22 Javascript
JavaScript编写一个简易购物车功能
Sep 17 Javascript
vue.js $refs和$emit 父子组件交互的方法
Dec 20 Javascript
解决vue-cli创建项目的loader问题
Mar 13 Javascript
mpvue 页面预加载新增preLoad生命周期的两种方式
Oct 17 Javascript
Element图表初始大小及窗口自适应实现
Jul 10 Javascript
微信小程序自定义胶囊样式
Dec 27 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 foreach 参数强制类型转换的问题
2010/12/10 PHP
PHP实现从远程下载文件的方法
2015/03/12 PHP
PHP生成树的方法
2015/07/28 PHP
给WordPress中的留言加上楼层号的PHP代码实例
2015/12/14 PHP
PHP Cookei记录用户历史浏览信息的代码
2016/02/03 PHP
ASP中进行HTML数据及JS数据编码函数
2009/11/11 Javascript
js中的如何定位固定层的位置
2014/06/15 Javascript
DOM操作一些常用的属性汇总
2015/03/13 Javascript
详解JavaScript UTC时间转换方法
2016/01/07 Javascript
Jquery中巧用Ajax的beforeSend方法
2016/01/20 Javascript
使用jQuery调用XML实现无刷新即时聊天
2016/08/07 Javascript
NodeJS中的MongoDB快速入门详细教程
2016/11/11 NodeJs
解决同一页面中两个iframe互相调用jquery,js函数的方法
2016/12/12 Javascript
js实现无缝滚动图
2017/02/22 Javascript
jQuery实现web页面樱花坠落的特效
2017/06/01 jQuery
vue实现的微信机器人聊天功能案例【附源码下载】
2019/02/18 Javascript
JavaScript中this用法学习笔记
2019/03/17 Javascript
前端vue-cli项目中使用img图片和background背景图的几种方法
2019/11/13 Javascript
[05:48]DOTA2英雄梦之声vol21 屠夫
2014/06/20 DOTA
深入解答关于Python的11道基本面试题
2017/04/01 Python
python numpy 显示图像阵列的实例
2018/07/02 Python
pyqt5 从本地选择图片 并显示在label上的实例
2019/06/13 Python
分享8点超级有用的Python编程建议(推荐)
2019/10/13 Python
python实现人机五子棋
2020/03/25 Python
浅析python中的del用法
2020/09/02 Python
香港永安旅游网:Wing On Travel
2017/04/10 全球购物
Lookfantastic葡萄牙官方网站:欧洲第一大化妆品零售商
2018/03/17 全球购物
查找廉价航班和发现新目的地:Kiwi.com
2019/02/25 全球购物
linux面试题参考答案(1)
2016/01/22 面试题
英语文学专业学生的自我评价
2013/10/31 职场文书
幼儿园评语大全
2014/04/17 职场文书
法律专业求职信
2014/05/24 职场文书
最美孝心少年事迹材料
2014/08/15 职场文书
党员对照检查材料
2014/09/22 职场文书
离职证明范本
2015/06/12 职场文书
高二化学教学反思
2016/02/22 职场文书