- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
vue 自定义指令.pdf
vue ⾃定义指令
vue ⾃定义指令
基础
除了内置指令,Vue .j s 也允许注册⾃定义指令。⾃定义指令提供⼀种机制将数据的变
化映射为 DOM 为。
可以⽤ Vue.directive(id, definition) ⽅法注册⼀个全局⾃定义指令,它接
收两个参数指令 ID 与定义对象。也可以⽤组件的 directives 选项注册⼀个局部⾃
定义指令。
钩⼦函数
定义对象可以提供⼏个钩⼦函数 (都是可选的):
bind :只调⽤⼀次,在指令第⼀次绑定到元素上时调⽤。
update : 在 bind 之后⽴即以初始值为参数第⼀次调⽤,之后每当绑定值变化
时调⽤,参数为新值与旧值。
unbind :只调⽤⼀次,在指令从元素上解绑时调⽤。
⽰例
Vue.directive(my-directive, {
bind: function () {
// 准备⼯作
// 例如,添加事件处理器或只需要运⾏⼀次的⾼耗任务
},
update: function (newValue, oldValue) {
// 值更新时的⼯作
// 会以初始值为参数调⽤⼀次
},
unbind: function () {
// 清理⼯作
// 例如,删除 bind() 添加的事件监听器
}
})
在注册之后,便可以在 Vue .j s 模板中这样⽤ (记着添加前缀 v-):
div v-my-directive=someValue /div
当只需要 update 函数时,可以传⼊⼀个函数替代定义对象:
Vue.directive(my-directive, function (value) {
// 这个函数⽤作 update()
})
指令实例属性
所有的钩⼦函数将被复制到实际的指令对象中,钩⼦内 this 指向这个指令对象。这
个对象暴露了⼀些有⽤的属性:
el: 指令绑定的元素。
vm: 拥有该指令的上下⽂ ViewModel 。
expression: 指令的表达式,不包括参数和过滤器。
arg: 指令的参数。
name: 指令的名字,不包含前缀。
modifiers: ⼀个对象,包含指令的修饰符。
descriptor: ⼀个对象,包含指令的解析结果。
你应当将这些属性视为只读的,不要修改它们。你也可以给指令对象添加⾃定义属
性,但是注意不要覆盖已有的内部属性。
⽰例:
div id=demo v-demo:hello.a.b=msg /div
Vue.directive(demo, {
bind: function () {
console.log(demo bound!)
},
update: function (value) {
this.el.innerHTML =
name - + + br +
expression - + this.expression + br +
argument - + this.arg + br +
modifiers - + JSON.stringify(this.modifiers) + br
value - + value
}
})
var demo = new Vue({
el: #demo,
data: {
msg: hello!
}
})
结果
对象字⾯量
如果指令需要多个值,可以传⼊⼀个 JavaScript 对象字⾯量。记住,指令可以使⽤任
意合法的 JavaScript 表达式:
div v-demo={ color: white, text: hello! } /div
Vue.directive(demo, function (value) {
console.log(value.color) // white
console.log(value.text) // hello!
})
字⾯修饰符
当指令使⽤了字⾯修饰符,它的值将按普通字符串处理并
您可能关注的文档
最近下载
- 工程观感质量评价标准.pdf VIP
- 2023-2024 学年高中语法专项练习单选100题-现在完成时-学生版.docx VIP
- 2023-2024 学年高中语法专项练习单选100题-非谓语动词-学生版.docx VIP
- 一种隔离RS485与RS422兼容电路.pdf VIP
- 2023-2024 学年高中语法专项练习单选100题-构词法-转化法-学生版.docx VIP
- 2023-2024 学年高中语法专项练习单选100题-时态辨析-学生版.docx VIP
- 2023-2024 学年高中语法专项练习单选100题-主谓一致-学生版.docx VIP
- 2023-2024 学年高中语法专项练习单选100题-被动语态-学生版.docx VIP
- 2023-2024 学年高中语法专项练习单选100题-动词-学生版.docx VIP
- 2023-2024 学年高中语法专项练习单选100题-虚拟语气-学生版.docx VIP
文档评论(0)