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


本文摘自PHP中文网,作者coldplay.xixi,侵删。

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,代码如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<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有一个对应的语法糖,也就是简写方式

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

简写方式如下:

1

2

3

4

<div id="app">

    <a :href="link">Vuejs官网</a>

    <img :src="logoUrl" alt=""/>

</div>

v-bind 绑定class

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

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

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

绑定class有两种方式:

  • 对象语法

  • 数组语法

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

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

1

2

3

4

5

6

7

8

9

10

用法一:直接通过{}绑定一个类

<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:点击按钮切换字体颜色

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

...

<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后跟的是一个数组。

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

阅读剩余部分

相关阅读 >>

vue.js与react.js区别是什么

vue.js服务端渲染是什么

vue.js怎么使用懒加载

浅谈vue.js中的props(单向数据流)

vue.js怎么监听路由变化

如何解决vue.js中文乱码问题

简书 jsplumb使用

webstorm怎样新建vue.js的项目

render函数生成图片弹窗的代码示例

15个vue.js高级面试问题

更多相关阅读请进入《vue.js》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...