ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Vue——自定义指令

2021-12-21 12:00:46  阅读:226  来源: 互联网

标签:el Vue directive 自定义 绑定 调用 VNode 指令


自定义指令:

  指令地址:src / components / instructions / test / index.js

import Vue from "vue";
Vue.directive("test-instructions",{
  // 只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置
  bind(){},
  // 被绑定元素插入父节点时调用(仅保证父节点存在,但不一定已被插入文档中)。
  inserted(el,binding,vnode,oldVnode){
    /* 
    el:指令所在绑定的元素,可以用来直接操作DOM
    binding:一个对象,包含一下属性:
        name:指令名,不包含 “ v- ” 前缀。
        value:指令的绑定值,例如:v-my-directive="1 + 1"中,绑定为 2 。
        oldValue:指令绑定的前一个值,尽在update和componentUpdated钩子中可用。无论值是否改变都可用。
        expression:字符串形式的指令表达式。例如:v-my-directive="1 + 1"中,表达式为 "1 + 1"。
        arg:传给指令的参数,可选。例如:v-my-directive:foo 中,参数为"foo"。
        modifiers:一个包含修饰符的对象。例如:v-my-directive.foo.bar 中,修饰符对象为{foo:true,bar:true}。
    vnode:Vue编译生成的虚拟节点。
    oldVnode:上一个虚拟节点,尽在 update 和 componentUpdated 钩子中可用。
    */
    testFunction(el);
  },
  // 所在组件的VNode更新时调用,但是可能发生在其子VNode更新之前。指令的值可能发生改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新。
  update(){},
  // 指令所在主键的VNode及其子VNode全部更新后调用。
  componentUpdated(el,binding,vnode,oldVnode){
    testFunction(el);
  },
  // 只调用一次,指令与元素解绑时调用
  unbind(){}
})
// 方法
function testFunction(table) {
  console.log("传入数据");
  console.log(table);
}

  

注册指令

  在main.js中

import "src/components/instructions/test/index"

  

指令调用

    <el-table v-test-instructions :data="tableData">
        <el-table-column label="序号" type="index"></el-table-column>
    </el-table>

  

标签:el,Vue,directive,自定义,绑定,调用,VNode,指令
来源: https://www.cnblogs.com/lucky-jun/p/15714691.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有