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 验证表单(form)中的单选(radio)值
Sep 08 Javascript
Web跨浏览器进程通信(Web跨域)
Apr 17 Javascript
js调用打印机打印网页字体总是缩小一号的解决方法
Jan 24 Javascript
JQuery实现的按钮倒计时效果
Dec 23 Javascript
Three.js学习之Lamber材质和Phong材质
Aug 04 Javascript
AngularJS 依赖注入详解及示例代码
Aug 17 Javascript
jquery hover 不停闪动问题的解决方法(亦为stop()的使用)
Feb 10 Javascript
自定义vue全局组件use使用、vuex的使用详解
Jun 14 Javascript
带你快速理解javascript中的事件模型
Aug 14 Javascript
js中script的上下放置区别,Dom的增删改创建操作实例分析
Dec 16 Javascript
vue props 一次传多个值实例
Jul 22 Javascript
vue抽出组件并传值实例
Jul 31 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 rsa加密解密使用详解
2015/01/14 PHP
Smarty模板简单配置与使用方法示例
2016/05/23 PHP
PHP+MySQL实现消息队列的方法分析
2018/05/09 PHP
js客户端快捷键管理类的较完整实现和应用
2010/06/08 Javascript
jquery tab插件制作实现代码
2010/06/22 Javascript
防止浏览器记住用户名及密码的简单实用方法
2013/04/22 Javascript
如何书写高质量jQuery代码(使用jquery性能问题)
2014/06/30 Javascript
IE6/IE7中JavaScript json提示缺少标识符、字符串或数字问题处理
2014/12/16 Javascript
JQuery创建DOM节点的方法
2015/06/11 Javascript
JavaScript实现获得所有兄弟节点的方法
2015/07/23 Javascript
js实现用户输入的小写字母自动转大写字母的方法
2017/01/21 Javascript
Bootstrap笔记之缩略图、警告框实例详解
2017/03/09 Javascript
js实现旋转木马效果
2017/03/17 Javascript
vue监听scroll的坑的解决方法
2017/09/07 Javascript
原生JS实现的自动轮播图功能详解
2018/12/28 Javascript
Vue.js组件实现选项卡以及切换特效
2019/07/24 Javascript
Vue-cli打包后如何本地查看的操作
2020/09/02 Javascript
[13:18]《一刀刀一天》之DOTA全时刻21:详解TI新赛制 A队再露獠牙
2014/06/24 DOTA
[10:39]DOTA2上海特级锦标赛音乐会纪录片
2016/03/21 DOTA
python通过加号运算符操作列表的方法
2015/07/28 Python
将Dataframe数据转化为ndarry数据的方法
2018/06/28 Python
自适应线性神经网络Adaline的python实现详解
2019/09/30 Python
解决Python import docx出错DLL load failed的问题
2020/02/13 Python
Python偏函数实现原理及应用
2020/11/20 Python
python录音并调用百度语音识别接口的示例
2020/12/01 Python
浅析css3中matrix函数的使用
2016/06/06 HTML / CSS
css3 伪类选择器快速复习小结
2019/09/10 HTML / CSS
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
如果重写了对象的equals()方法,需要考虑什么
2014/11/02 面试题
有abstract方法的类一定要用abstract修饰吗
2016/03/14 面试题
基层干部十八大感言
2014/01/19 职场文书
汽车机修工岗位职责
2014/03/06 职场文书
房屋出租委托书格式
2014/09/23 职场文书
预备党员群众路线教育实践活动思想汇报2014
2014/10/25 职场文书
财政局个人总结
2015/03/04 职场文书
设备技术员岗位职责
2015/04/11 职场文书