vue2系列 — 自定义指令

https://v2.cn.vuejs.org/v2/guide/custom-directive.html

<div v-example:foo.bar="baz">

vue 自定义指令的钩子

  • bind: 当 v-XXX 指令绑定到节点上时 触发
  • inserted:被绑定元素插入父节点时调用
  • update:所在组件的 VNode 更新时调用

指令钩子函数会被传入以下参数:

  • el:指令所绑定的元素,可以用来直接操作 DOM
  • binding:一个对象,包含以下 property:
    • name:指令名,不包括 v- 前缀。
    • arg:传递给指令的参数 (如果有的话)。例如在 v-my-directive:foo 中,参数是 "foo"
    • value:指令的绑定值,例如:v-my-directive="1 + 1" 中,绑定值为 2
    • instance:使用该指令的组件实例。

使用方法:

  • 创建一个 js 文件

    • export default {
        // bind钩子 当 v-XXX 指令绑定到节点上时 触发
        bind (el) {
          el.oninput = () => {
            console.log('1', el)
            // 正则
            let pattern = new RegExp("[`~!@#$^&*()=|{}':;',\\[\\].<>/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]");
            // 将正则匹配到的字符,替换成 ''  赋予输入框节点的值
            el.children[0].value = el.children[0].value.replace(pattern, '');
          };
        }
      }
      
  • vue 文件中,import 引入文件

  • 并在 directives 中定义

    • directives: {
          limitInput
      }
      
  • 在输入框上使用: <el-input v-model="name" v-limit-input></el-input>

将一个自定义指令全局注册: 在main.js写

// 使 v-focus 在所有组件中都可用
app.directive('focus', {
  /* ... */
})

](https://v2.cn.vuejs.org/v2/guide/custom-directive.html)

<div v-example:foo.bar="baz">

vue 自定义指令的钩子

  • bind: 当 v-XXX 指令绑定到节点上时 触发
  • inserted:被绑定元素插入父节点时调用
  • update:所在组件的 VNode 更新时调用

指令钩子函数会被传入以下参数:

  • el:指令所绑定的元素,可以用来直接操作 DOM
  • binding:一个对象,包含以下 property:
    • name:指令名,不包括 v- 前缀。
    • arg:传递给指令的参数 (如果有的话)。例如在 v-my-directive:foo 中,参数是 "foo"
    • value:指令的绑定值,例如:v-my-directive="1 + 1" 中,绑定值为 2
    • instance:使用该指令的组件实例。

使用方法:

  • 创建一个 js 文件

    • export default {
        // bind钩子 当 v-XXX 指令绑定到节点上时 触发
        bind (el) {
          el.oninput = () => {
            console.log('1', el)
            // 正则
            let pattern = new RegExp("[`~!@#$^&*()=|{}':;',\\[\\].<>/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]");
            // 将正则匹配到的字符,替换成 ''  赋予输入框节点的值
            el.children[0].value = el.children[0].value.replace(pattern, '');
          };
        }
      }
      
  • vue 文件中,import 引入文件

  • 并在 directives 中定义

    • directives: {
          limitInput
      }
      
  • 在输入框上使用: <el-input v-model="name" v-limit-input></el-input>

将一个自定义指令全局注册: 在main.js写

// 使 v-focus 在所有组件中都可用
app.directive('focus', {
  /* ... */
})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值