详解vue.js之绑定class和style的示例代码


Posted in Javascript onAugust 24, 2017

一.绑定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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript制作的网页侧边弹出框思路及实现代码
May 21 Javascript
JavaScript页面模板库handlebars的简单用法
Mar 02 Javascript
IE浏览器下PNG相关功能
Jul 05 Javascript
14 个折磨人的 JavaScript 面试题
Aug 08 Javascript
微信小程序 简单DEMO布局,逻辑,样式的练习
Nov 30 Javascript
JS中使用 after 伪类清除浮动实例
Mar 01 Javascript
js实现上下左右弹框划出效果
Mar 08 Javascript
BootStrap中jQuery插件Carousel实现轮播广告效果
Mar 27 jQuery
全新打包工具parcel零配置vue开发脚手架
Jan 11 Javascript
vue.js删除列表中的一行
Jun 30 Javascript
详解如何运行vue项目
Apr 15 Javascript
在vue中封装的弹窗组件使用队列模式实现方法
Jul 23 Javascript
10个最优秀的Node.js MVC框架
Aug 24 #Javascript
Vue.js实现输入框绑定的实例代码
Aug 24 #Javascript
Vue.js实现价格计算器功能
Mar 30 #Javascript
js微信分享实现代码
Oct 11 #Javascript
Vue.js实现实例搜索应用功能详细代码
Aug 24 #Javascript
实例详解JSON取值(key是中文或者数字)方式
Aug 24 #Javascript
JSON创建键值对(key是中文或者数字)方式详解
Aug 24 #Javascript
You might like
回首过去10年中最搞笑的10部动漫,哪一部让你节操尽碎?
2020/03/03 日漫
通俗易懂的php防注入代码
2010/04/07 PHP
PHP面向对象概念
2011/11/06 PHP
一个简单至极的PHP缓存类代码
2015/10/23 PHP
WordPress开发中短代码的实现及相关函数使用技巧
2016/01/05 PHP
php生成酷炫的四个字符验证码
2016/04/22 PHP
PHP之十六个魔术方法详细介绍
2016/11/01 PHP
PHP实现上传多图即时显示与即时删除的方法
2017/05/09 PHP
jQuery使用hide方法隐藏指定元素class样式用法实例
2015/03/30 Javascript
javascript+HTML5的canvas实现七夕情人节3D玫瑰花效果代码
2015/08/04 Javascript
JS实现从网页顶部掉下弹出层效果的方法
2015/08/06 Javascript
javascript三种代码注释方法
2016/06/02 Javascript
angularjs过滤器--filter与ng-repeat配合有奇效
2017/04/20 Javascript
Angular 表单控件示例代码
2017/06/26 Javascript
Vue学习笔记进阶篇之多元素及多组件过渡
2017/07/19 Javascript
浅谈开发eslint规则
2018/10/01 Javascript
Vue路由 重定向和别名的区别说明
2020/09/09 Javascript
详解JavaScript 的执行机制
2020/09/18 Javascript
[03:31]DOTA2英雄基础教程 大地之灵
2013/12/17 DOTA
Python中字符串对齐方法介绍
2015/05/21 Python
举例讲解Python中的死锁、可重入锁和互斥锁
2015/11/05 Python
Python网络编程之TCP套接字简单用法示例
2018/04/09 Python
解决PyCharm控制台输出乱码的问题
2019/01/16 Python
python网络编程之多线程同时接受和发送
2019/09/03 Python
利用pytorch实现对CIFAR-10数据集的分类
2020/01/14 Python
Spring http服务远程调用实现过程解析
2020/06/11 Python
python语言实现贪吃蛇游戏
2020/11/13 Python
python 日志模块logging的使用场景及示例
2021/01/04 Python
德国网上药房:Apotal
2017/04/04 全球购物
Allsole美国/加拿大:英国一家专门出售品牌鞋子的网站
2018/10/21 全球购物
学术会议欢迎词
2014/01/09 职场文书
好矿嫂事迹材料
2014/01/21 职场文书
致百米运动员广播稿
2014/01/29 职场文书
办公室主任竞聘演讲稿
2014/05/15 职场文书
财政局党的群众路线教育实践活动整改方案
2014/09/21 职场文书
FFmpeg视频处理入门教程(新手必看)
2022/01/22 杂记