首页 > 其他 > 详细

vue-learning:6-template-v-bind

时间:2019-05-19 21:01:08      阅读:115      评论:0      收藏:0      [点我收藏+]

绑定元素特性的指令v-bind

回顾下,从HTML元素的结构看,在VUE框架中,内容由插值{{ }}v-html绑定;v-ifv-show可以控制元素的可见性;v-for可以用于批量生成列表元素。

这一节介绍下绑定元素特性的指令v-bind的用法:

v-bind:attribute = value
v-bind:attribute = expression

// v-bind 简写 :
:attribute = value
:attribute = expression

点击查看DEMO v-bind on attribute

<div id="app">
    <button v-bind:disabled = "disabledForBtn">click me</button>
</div>
new Vue({
    el: "#app",
    data: {
        disabledForBtn: true
    }
})

这个例子当disabledForBtn为真值时,按钮被禁用,即disabled特性生效。其中disabled称为指令v-bind的参数,而=后面的值其它指令一样,可以是具体的布尔值类型值,也可以表达式试算的结果值。

<div id="app">
    <input v-bind:disabled = "new Date().getHours() > 12" />
</div>

但通常不建议将复杂计算写在tempalte模板中,可以使用后面要讲到的计算属性来表达,使代码更为简洁。

<div id="app">
    <input v-bind:disabled = "isCanUseInput" />
</div>
new Vue({
    el: "#app",
    data: {
        canUseBtn: true
    },
    computed: {
       isCanUseInput: () => new Date().getHours() > 12
    }
})

当在页面中有大写特性绑定,需要反复书写v-bind相当重复工作,所以Vue提供了简写方式:用冒号:代替v-bind

<button :disabled = "disabledForBtn">click me</button>
<input  :disabled = "new Date().getHours() > 12" />
<input  :disabled = "isCanUseInput" />

无论选择用v-bind还是简写冒号的形式,建议在页面中都尽量保持一致性。

HTML元素中有两个特殊的特性,classstyel,下一节具体讲解。

vue-learning:6-template-v-bind

原文:https://www.cnblogs.com/webxu20180730/p/10890557.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!