VueJS入门教程之七:自定义指令(detective)

桃扇骨 2022-04-21 14:50 306阅读 0赞

除了核心功能默认内置的指令 (v-modelv-show),Vue 也允许注册自定义指令。注意,在 Vue2.0 中,代码复用和抽象的主要形式是组件。然而,有的情况下,你仍然需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令。举个聚焦输入框的例子,如下:

当页面加载时,该元素将获得焦点 (注意:autofocus 在移动版 Safari 上不工作)。事实上,只要你在打开这个页面后还没点击过任何内容,这个输入框就应当还是处于聚焦状态。现在让我们用指令来实现这个功能:

全局指令

  1. // 注册一个全局自定义指令 `v-focus`
  2. Vue.directive('focus', {
  3. // 当被绑定的元素插入到 DOM 中时……
  4. inserted: function (el) {
  5. // 聚焦元素
  6. el.focus()
  7. }
  8. })

如果想注册局部指令,组件中也接受一个 directives 的选项:

局部指令

  1. directives: {
  2. focus: {
  3. // 指令的定义
  4. inserted: function (el) {
  5. el.focus()
  6. }
  7. }
  8. }

然后你可以在模板中任何元素上使用新的 v-focus 属性,如下:

使用方法

  1. <input v-focus/>

发表评论

表情:
评论列表 (有 0 条评论,306人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Vue定义指令

    自定义指令 场景 > 在vue 2.0中,有的情况下,你需要对普通DOM元素进行底层操作,这时候就需要用到自定义指令! 除了核心功能默认内置的指令 (v-model

    相关 vue初学习()——定义指令

    自定义指令是指当一些指令不够用的时候需要自己自定义一些指令来实现对应的功能 自定义指令分为局部和全局的,和过滤器filter一样,局部的可以一次性定义多个指令,全局的实例化一

    相关 定义指令

    前言 除了 AngularJS 内置的指令外,我们还可以创建自定义指令。  通过 .directive() 函数来添加自定义的指令。  调用自定义指令时,需要在H