vue 自定义指令.pdfVIP

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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! }) 字⾯修饰符 当指令使⽤了字⾯修饰符,它的值将按普通字符串处理并

文档评论(0)

zhoujiahao + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档