Vue的Class与Style绑定的方法


Posted in Javascript onSeptember 01, 2017

本文介绍了Vue的Class与Style绑定,分享给大家,具体如下:

绑定 HTML Class

对象语法

我们可以传给 v-bind:class 一个对象,以动态地切换 class:

<style>
  .exp{
    border: 1px solid #ccc;
  }
  .forExp{
    background: blue;
  }
</style>
<div class="exp" v-bind:class="{newExp:isNewExp}"></div>
<script>
  var exp=new Vue({
    el:".exp".
    data:{
      isForExp:false
    }
  })
</script>

如上,我们先给 .exp 一个边框,我们利用 v-bind 方法传入一个新的 class 属性 .newExp,设置一个蓝色的背景颜色。当我们在控制台修改 .newExp 的属性为 true 时,会给 div 添加一个蓝色的背景颜色。

我们也可以传入更多的属性来切换多个 class 。

<div class="exp" v-bind:class="{newExp:isExp,npc:isNpc}"></div>
<script>
  data:{
    isExp:false,
    isNpc:true
  }
</script>

在模板里的渲染结果为:

<div class="exp isNpc"></div>

我们也可以使用对象的方法来切换属性

<div class="exp" v-bind:class="obj"></div>
<script>
  data:{
    obj:{
      newExp:false,
      npc:true
    }
  }
</script>

渲染结果和上面的一样

数组语法

我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:

<div class="exp" v-bind:class="[newExp,oldExp]"></div>
<script>
  data:{
    newExp:"new",
    oldExp:"old"
  }
</script>

渲染为:

<div class="exp new old"></div>

要切换class,使用三元运算符:

<div class="exp" v-bind:class="[act? newExp:oldExp]"></div>
<script>
  data{
    newExp:"new",
    oldExp:"old",
    act:true
  }
<script>

act 为 true 时,添加 new ,为 false 时添加 old。

用在组件上

声明一个组件:

Vue.component("my", {
  template: '<p class="foo bar">Hi</p>'
})

然后在使用它的时候添加一些 class:

<my class="tip"></my>

最终渲染为

<p class="foo bar tip">Hi</p>

同样的适用于绑定 HTML class:

<my v-bind:class="{ active: isActive }"></my>

当active为true时,HTML 将被渲染成为:

<p class="foo bar active">Hi</p>

绑定内联样式

对象语法

v-bind:style 的对象语法十分直观——看着非常像 CSS,其实它是一个 JavaScript 对象。 CSS 属性名可以用驼峰式 (camelCase) 或 (配合引号的) 短横分隔命名 (kebab-case):

<div v-bind:style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
<script>
  data:{
    activeColor:"blue",
    fontSize:20
  }
</script>

使用对象语法的话,会看起来更加清晰

<div v-bind:style="obj"></div>
<script>
  data:{
    obj:{
      color:"#FFF",
      fontSize:"20px"
    }
  }
</script>

数组语法

v-bind:style 的数组语法可以将多个样式对象应用到一个元素上:

<div v-bind:style="[style1,style2]"></div>
<script>
  data:{
    style1:{
      color:"#666"
    },
    style2:{
      background:"#b1b1b1"
    }
  }
</script>

自动添加前缀

当 v-bind:style 使用需要特定前缀的 CSS 属性时,如 transform,Vue.js 会自动侦测并添加相应的前缀。

Chrome 和 Safari : -webkit-
IE :        -ms-
Firfox :      -moz-
Opera :      -o-

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

Javascript 相关文章推荐
js网页实时倒计时精确到秒级
Feb 10 Javascript
javascript中的原型链深入理解
Feb 24 Javascript
JavaScript 作用域链解析
Nov 13 Javascript
推荐10 款 SVG 动画的 JavaScript 库
Mar 24 Javascript
js+html5绘制图片到canvas的方法
Jun 05 Javascript
JS+CSS实现表格高亮的方法
Aug 05 Javascript
JS获取鼠标选中的文字
Aug 10 Javascript
javascript 定时器工作原理分析
Dec 03 Javascript
node.js中cluster的使用教程
Jun 09 Javascript
javascript实现文字无缝滚动效果
Aug 26 Javascript
30分钟快速入门掌握ES6/ES2015的核心内容(上)
Apr 18 Javascript
web页面和微信小程序页面实现瀑布流效果
Sep 26 Javascript
Angular中封装fancyBox(图片预览)遇到问题小结
Sep 01 #Javascript
BootStrap模态框和select2合用时input无法获取焦点的解决方法
Sep 01 #Javascript
Angularjs实现上传图片预览功能
Sep 01 #Javascript
JavaScript中使用参数个数实现重载功能
Sep 01 #Javascript
bootstrap-table实现服务器分页的示例 (spring 后台)
Sep 01 #Javascript
jQuery EasyUI结合zTree树形结构制作web页面
Sep 01 #jQuery
基于Vue.js 2.0实现百度搜索框效果
Dec 28 #Javascript
You might like
深入PHP购物车模块功能分析(函数讲解,附源码)
2013/06/25 PHP
PHP自定义递归函数实现数组转JSON功能【支持GBK编码】
2018/07/17 PHP
Thinkphp 框架配置操作之配置加载与读取配置实例分析
2020/05/15 PHP
jquery实现隐藏与显示动画效果/输入框字符动态递减/导航按钮切换
2013/07/01 Javascript
javascript在网页中实现读取剪贴板粘贴截图功能
2014/06/07 Javascript
JavaScript程序设计之JS调试
2015/12/09 Javascript
Spring MVC中Ajax实现二级联动的简单实例
2016/07/06 Javascript
JS遍历对象属性的方法示例
2017/01/10 Javascript
JavaScript编程设计模式之构造器模式实例分析
2017/10/25 Javascript
javascript中UMD规范的代码推演
2018/08/29 Javascript
使用JavaScript破解web
2018/09/28 Javascript
eslint 的三大通用规则详解
2019/05/16 Javascript
bootstrap实现嵌套模态框的实例代码
2020/01/10 Javascript
JS实现炫酷雪花飘落效果
2020/08/19 Javascript
[01:35]辉夜杯战队访谈宣传片—LGD
2015/12/25 DOTA
[46:50]Liquid vs Mineski 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
用Python编写一个简单的Lisp解释器的教程
2015/04/03 Python
让python 3支持mysqldb的解决方法
2017/02/14 Python
Python 实现淘宝秒杀的示例代码
2018/01/02 Python
Python基于csv模块实现读取与写入csv数据的方法
2018/01/18 Python
python 查找文件名包含指定字符串的方法
2018/06/05 Python
python 3调用百度OCR API实现剪贴板文字识别
2018/09/04 Python
pycharm 配置远程解释器的方法
2018/10/28 Python
在python中实现将一张图片剪切成四份的方法
2018/12/05 Python
python 和c++实现旋转矩阵到欧拉角的变换方式
2019/12/04 Python
Pytorch Tensor基本数学运算详解
2019/12/30 Python
大学毕业生文采飞扬的自我鉴定
2013/12/03 职场文书
大学生实习自我鉴定
2013/12/11 职场文书
司仪主持词两篇
2014/03/22 职场文书
借款协议书
2014/04/12 职场文书
党的群众路线教育实践活动个人对照检查材料(企业)
2014/11/05 职场文书
党委工作总结2015
2015/04/27 职场文书
婚礼答谢词范文
2015/09/29 职场文书
2016大学迎新欢迎词
2015/09/29 职场文书
AI:如何训练机器学习的模型
2021/04/16 Python
常用的MongoDB查询语句的示例代码
2021/07/25 MongoDB