(详解)Vue自定义指令

一、背景

在我们日常开发中,会遇到特殊的操作例如,图片懒加载,和类似v-model等等这样的自定义指令

二、提前预习(必看)

自定义指令跟组件一样,也是有生命周期的 ,我们的操作都是定义在对应的生命周期中 ,然后进行操作的,然后通过钩子函数传参进行绑定事件等等(先了解下)

2.1自定义指令生命周期

  • created:在绑定元素的 attribute 或事件监听器被应用之前调用;
  • beforeMount:当指令第一次绑定到元素并且在挂载父组件之前调用;
  • mounted:在绑定元素的父组件被挂载后调用,大部分自定义指令都写在这里;
  • beforeUpdate:在更新包含组件的 VNode 之前调用;
  • updated:在包含组件的 VNode 及其子组件的 VNode 更新后调用;
  • beforeUnmount:在卸载绑定元素的父组件之前调用;
  • unmounted:当指令与元素解除绑定且父组件已卸载时,只调用一次;

2.2 生命周期四个参数

这里七个钩子函数,钩子函数中有回调参数,回调参数有四个,含义基本上和 Vue2 一致:

  • el:指令所绑定的元素,可以用来直接操作 DOM(可以进行事件绑定)。

  • binding:我们通过自定义指令传递的各种参数

  • vnode:Vue 编译生成的虚拟节点。

  • oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。

三、 自定义指令

3.1私有自定义指令

3.1.1定义指令

在每个 vue 组件中,可以在 directives 节点下声明私有自定义指令。示例代码如下:

复制代码
<script>
export default {
  directives: {
      // 自定义私有指令focus,在使用的时候要用 v-focus 。
    focus: {
      mounted(el, binding, vnode) => {
        //el是对应的dom,可以通过el给对应添加事件监听 el.addEventListener
        // binding.value 就是通过 = 绑定的值,在传值的时候传到这 binding.value
        //vnode是节点
        }
    },
  },
}
</script>

3.1.2使用自定义指令

在使用自定义指令时,需要加上 v- 前缀。示例代码如下:

复制代码
<!-- 声明自定义私有指令focus,在使用的时候要用 v-focus 。 -->    
<input v-focus/>

3.2全局自定义指令

3.2.1定义指令

全局共享的自定义指令需要通过"单页面应用程序的实例对象"进行声明,示例代码如下:

复制代码
import { createApp } from 'vue'
 
const app = createApp({
  /* ... */
})
 
// 注册(对象形式的指令)
app.directive('my-directive', {
  /* 自定义指令钩子 */
    mounted(el, bindings) {
      
    }
 
})
 
// 注册(函数形式的指令)
app.directive('my-directive', (el, binding, vnode) => {
        //el是对应的dom,可以通过el给对应添加事件监听 el.addEventListener
        // binding.value 就是通过 = 绑定的值,在传值的时候传到这 binding.value
        //vnode是节点
        })

3.2.2使用自定义指令

在使用自定义指令时,需要加上 v- 前缀。示例代码如下:

复制代码
<!-- 声明自定义私有指令focus,在使用的时候要用 v-focus 。 -->    
<input v-focus/>
相关推荐
小二·1 分钟前
Python Web 开发进阶实战(终章):从单体应用到 AI 原生生态 —— 45 篇技术演进全景与未来开发者生存指南
前端·人工智能·python
m0_6372565825 分钟前
vue-baidu-map添加了类型组件导致非常卡顿的问题
前端·javascript·vue.js
雨季66627 分钟前
基于设备特征的响应式 UI 构建:Flutter for OpenHarmony 中的智能布局实践
javascript·flutter·ui
挂机且五杀28 分钟前
为什么在React地图组件里,memo 不是优化,而是生存?
前端·react.js·前端框架
RFCEO30 分钟前
HTML编程 课程七、:HTML5 新增表单标签与属性
前端·html·html5·搜索框·手机号·邮箱验证·日期选择
刘一说1 小时前
Vue开发中的“v-model陷阱”:为什么它不能用于非表单元素?
前端·javascript·vue.js
利刃大大1 小时前
【Vue】组件生命周期 && 组件生命周期钩子
前端·javascript·vue.js·前端框架
建群新人小猿3 小时前
陀螺匠企业助手—个人简历
android·大数据·开发语言·前端·数据库
CHU7290353 小时前
在线教学课堂APP前端功能:搭建高效线上教学生态
前端·人工智能·小程序·php
be or not to be3 小时前
JavaScript 对象与原型
开发语言·javascript·ecmascript