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 相关文章推荐
jQuery EasyUI 中文API Button使用实例
Apr 14 Javascript
Jquery Change与bind事件代码
Sep 29 Javascript
jQuery给多个不同元素添加class样式的方法
Mar 26 Javascript
jQuery选择器源码解读(一):Sizzle方法
Mar 31 Javascript
防止Node.js中错误导致进程阻塞的办法
Aug 11 Javascript
Angular表单验证实例详解
Oct 20 Javascript
js/jquery控制页面动态加载数据 滑动滚动条自动加载事件的方法
Feb 08 Javascript
layui获取多选框中的值方法
Aug 15 Javascript
移动端(微信等使用vConsole调试console的方法
Mar 05 Javascript
jquery中为什么能用$操作
Jun 18 jQuery
利用d3.js实现蜂巢图表带动画效果
Sep 03 Javascript
微信小程序wx.request的简单封装
Nov 13 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实现采集程序原理和简单示例代码
2007/03/18 PHP
详解php框架Yaf路由重写
2017/06/20 PHP
PHP进阶学习之垃圾回收机制详解
2019/06/18 PHP
php中文语义分析实现方法示例
2019/09/28 PHP
js 操作css实现代码
2009/06/11 Javascript
优化javascript的执行速度
2010/01/23 Javascript
js显示时间 js显示最后修改时间
2013/01/02 Javascript
往光标所在位置插入值的js代码
2013/09/22 Javascript
使用jquery实现鼠标滑过弹出更多相关信息层附源码下载
2015/11/23 Javascript
浅谈$('div a') 与$('div&gt;a')的区别
2016/07/18 Javascript
JavaScript实现的数字与字符串转换功能示例
2017/08/23 Javascript
vue项目中使用axios上传图片等文件操作
2017/11/02 Javascript
vue.js实现只弹一次弹框
2018/01/29 Javascript
js传递数组参数到后台controller的方法
2018/03/29 Javascript
vue动态配置模板 'component is'代码
2019/07/04 Javascript
Python易忽视知识点小结
2015/05/25 Python
python利用有道翻译实现&quot;语言翻译器&quot;的功能实例
2017/11/14 Python
解决Python获取字典dict中不存在的值时出错问题
2018/10/17 Python
Python查找文件中包含中文的行方法
2018/12/19 Python
python变量命名的7条建议
2019/07/04 Python
PyQt5多线程刷新界面防假死示例
2019/12/13 Python
PyCharm汉化安装及永久激活详细教程(靠谱)
2020/01/16 Python
PyQt实现计数器的方法示例
2021/01/18 Python
使用JS+CSS3技术:让你的名字动起来
2013/04/27 HTML / CSS
澳大利亚时尚前卫设计师珠宝在线:Amber Sceats
2017/10/04 全球购物
捷克体育用品购物网站:D-sport
2017/12/28 全球购物
美国女士时尚珠宝及配饰购物网站:Icing
2018/07/02 全球购物
实习教师自我鉴定
2013/12/09 职场文书
英语专业毕业生自荐信范文
2013/12/31 职场文书
十八届三中全会报告学习材料
2014/02/17 职场文书
税务干部个人整改措施思想汇报
2014/10/10 职场文书
加强干部作风建设整改方案
2014/10/24 职场文书
企业介绍信范文
2015/01/30 职场文书
商超业务员岗位职责
2015/02/13 职场文书
2015年城乡环境综合治理工作总结
2015/07/24 职场文书
分享很少见很有用的SQL功能CORRESPONDING
2022/08/05 MySQL