vue.js中v-bind是什么意思

互联网 20-11-10

vue.js中【v-bind】是用于绑定一个多多个属性值,或者像一个组件创建props值,【v-bind】有一个对应的语法糖,也就是简写方式,利于语法简洁。

本教程操作环境:windows10系统、vue2.9,本文适用于所有品牌的电脑。

【相关文章推荐:vue.js】

v-bind的介绍

前面我们学习的指令主要作用是将值插入到我们模板的内容当中。

但是,除了内容需要动态来决定外,某些属性我们也希望动态来绑定。

  • 比如动态绑定a元素的href属性

  • 比如动态绑定img元素的src属性

这个时候,我们可以使用v-bind指定:

  • 作用:动态绑定属性

  • 缩写::

  • 预期:any(with argument) | object (whitout argument)

  • 参数:attrOrProp(option)

v-bind基础

v-bind用于绑定一个多多个属性值,或者像一个组件创建props值(这个我们在学到组件时再介绍)

在开发中,有哪些属性需要进行动态绑定呢?

比如图片的链接(src)、网站的链接(href)、动态绑定一些类(class)、样式(style)等等

比如通过Vue实例中的data绑定元素的src和href,代码如下

<div id="app">     <a v-bind:href="link">Vuejs官网</a>     <img v-bind:src="logoUrl" alt=""/>          <!-- 当然也可以通过语法糖“:”缩写v-bind -->     <!-- <img :src="logoUrl" alt=""/> --> </div> <script src="/vue.js"></script> <script>     let app = new Vue({         el:"#app",         data:{             logoUrl:"http://vuejs.org/images/logo.png",             link:"https://vuejs.org"         }     }) </script>

v-bind语法糖

v-bind有一个对应的语法糖,也就是简写方式

在开发中,我们通常会使用语法糖的形式,因为这样更加简洁。

简写方式如下:

<div id="app">     <a :href="link">Vuejs官网</a>     <img :src="logoUrl" alt=""/> </div>

v-bind 绑定class

很多时候,我们希望动态的来切换class,比如:

  • 当数据为某个状态时,字体显示红色。

  • 当数据为另一个状态时,字体显示黑色。

绑定class有两种方式:

  • 对象语法

  • 数组语法

对象语法的含义是:class后面跟一个对象。

对象语法有下面这些用法:

用法一:直接通过{}绑定一个类 <h2 :class="{active:isActive}">Hello world</h2> 用法二:也可以通过判断,传入多个值 <h2 :class="{active:isActive,line:isLine}">Hello world</2>   用法三:和普通的类同时存在,并不冲突 注:如果isActive和IsLine都为true,那么会有title/active/line三个类 <h2 class="title" :class="{active:isActive,line:isLine}">Hello world</h2> 用法四:如果过于复杂,可以放在一个methods或者computed中 注:classes是一个计算属性 <h2 class="title" :class="classes">Hello world</h2>

Demo:点击按钮切换字体颜色

... <style>     .active{         color:red;     }     </style ... <div id="app"> <h1 v-bind:class="{active:isActive}">{{message}}</h1> <button v-on:click="buttonClick()">颜色切换</button> </div> <script> const vue = new Vue({ el: '#app', data: { message: 'hello world', isActive:true }, methods:{ buttonClick:function(){ this.isActive = !this.isActive; } } }) </script>

数组语法的含义是:class后跟的是一个数组。

数组语法有下面这些用法(数组语法一般用的比较少):

用法一:直接通过[]绑定一个类 <h2 :class="[active]">Hello world</h2> 用法二:也可以传入多个值 <h2 :class="[active,line]">Hello world</2> 用法三:和普通的类同时存在,并不冲突 注:会有title/active/line三个类 <h2 class="title" :class="[active,line]">Hello world</h2> 用法四:如果过于复杂,可以放在一个methods或者computed中 注:classes是一个计算属性 <h2 class="title" :class="classes">Hello world</h2>

Demo:

...  <style> .active{ color: red; } .line{ font-size: 50px; } .common{ color:green; } </style> ... <div id="app">     <!-- 如果加了单引号用的就是style中的指定class,如果没有单引号用的就是vue对象中的active变量 -->     <!-- 注:这里,下面三个类将共存--> <h2 class="common" :class="['active',line]">Hello world</h2> </div> <script> const vue = new Vue({ el: '#app', data: { line:'line' } }) </script>

v-bind绑定style

我们可以利用v-bind:style来绑定一些CSS内联样式

在写CSS属性名的时候,比如font-size

  • 我们可以使用驼峰式(cameCase):fontSize

  • 或短横线分隔(kebab-case,记得用单引号括起来)'font-size'

绑定class有两种方式:

  • 对象语法

  • 数组语法

对象语法的含义就是style后面跟的是一个对象类型

<!-- 对象key是CSS属性名称 --> <!-- 对象value是具体赋的值,值可以来自于data中的属性 --> :style="{coloc:currentColor,fontsize:fontsize+'px'}"

数组语法的含义就是style后面跟的是一个数组类型

<!-- 多个值以,分割即可--> <div v-bind:style="[baseStyles,overridingStyles]"></div>

Demo:

<div id="app"> <!-- 通过对象绑定style行内样式,值如果为字符串,那么将直接显示样式值 --> <!-- <h1 :style="{color:'red'}">{{message}}</h1> --> <!-- 通过变量来绑定行内样式表 --> <!-- <h1 :style="{color:color}">{{message}}</h1> --> <!-- 通过方法来绑定样式 --> <!-- <h1 :style="getStyle()">{{message}}</h1> --> <!-- 通过数组来绑定样式 --> <h1 :style="[common,bgColor]">{{message}}</h1> </div> <script type="text/javascript"> const vue = new Vue({ el: "#app", data: { message: "hello world", color: 'red', common:{color:'blue',fontSize:'10px'}, bgColor:{backgroundColor:'black'} }, methods: { getStyle: function() { return { color: this.color }; } } }) </script>

相关免费学习推荐:javascript(视频)

以上就是vue.js中v-bind是什么意思的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: v-bind
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:java多态机制是什么

相关资讯