Vue3 指令详解

一、构建指令

1. 生命周期

**created:**在指令被绑定到元素之前调用。这个钩子很少使用,因为指令通常在元素存在时才需要进行操作。

**beforeMount:**在指令绑定的元素被插入到 DOM 之前调用。

**mounted:**在指令绑定的元素被插入到 DOM 后调用。这是最常用的生命周期钩子之一,通常在这里进行对元素的初始化操作。

**beforeUpdate:**在包含指令的组件更新之前调用。当组件的响应式数据发生变化导致组件重新渲染时,这个钩子会被触发。

**updated:**在包含指令的组件更新后调用。可以在这里对更新后的元素进行操作。

**beforeUnmount:**在指令绑定的元素被从 DOM 中移除之前调用。可以在这里进行一些清理操作,例如移除事件监听器等。

**unmounted:**在指令绑定的元素被从 DOM 中移除后调用。这是另一个进行清理操作的好时机。

javascript 复制代码
const myDirective = {

  created(el, binding, vnode) {

    console.log("指令创建");

  },

  beforeMount(el, binding, vnode) {

    console.log("指令在元素插入 DOM 前");

  },

  mounted(el, binding, vnode) {

    console.log("指令在元素插入 DOM 后");

  },

  beforeUpdate(el, binding, vnode, prevVnode) {

    console.log("指令在组件更新前");

  },

  updated(el, binding, vnode, prevVnode) {

    console.log("指令在组件更新后");

  },

  beforeUnmount(el, binding, vnode) {

    console.log("指令在元素移除 DOM 前");

  },

  unmounted(el, binding, vnode) {

    console.log("指令在元素移除 DOM 后");

  },

};



export default myDirective;

2. 生命周期参数

生命周期函数参数el、binding、vnode、prevNode,分别表示:

**el:**指令绑定的元素。可进行 DOM 操作。

**binding:**一个对象,包含以下属性:

value:指令的绑定值。

arg:传递给指令的参数,如果没有参数则为 undefined。

modifiers:一个包含指令修饰符的对象。

oldValue:上一次更新时的旧值,仅在 beforeUpdate 和 updated 钩子中可用。

**vnode:**虚拟节点。

**prevNode:**上一次更新前的虚拟节点。

html 复制代码
<input v-focus:a.b="10" />

<!--

{

  value: 10,

  arg: 'a',

  modifiers: { b: true },

  oldValue: /* 上一次更新时 value 的值 */

} -->

3. 创建指令

在 src/directive 下创建一个 Focus.js 文件,用来自动 input 获取焦点。

javascript 复制代码
// Focus.js

const Focus = {

  mounted: (el) => el.focus(),

};



export default Focus;

二、引入指令

在 src/main.js 中引入指令

javascript 复制代码
// main.js

import { createApp } from "vue";

import App from "./App.vue";

/** 指令 */

import Focus from "@/directive/Focus.js";



const app = createApp(App);

app.directive("focus", Focus);

app.mount("#app");

三、使用指令

在组件中使用指令

javascript 复制代码
<input v-focus v-model="value" />
相关推荐
IT_陈寒12 小时前
SpringBoot这个自动配置坑我跳了三次
前端·人工智能·后端
kyriewen12 小时前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher13 小时前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
默_笙13 小时前
🃏 JS 只有 8 种数据类型,但我花了 2 天才搞懂 null 和 undefined 的区别
javascript
牧艺13 小时前
从零到协同:构建类飞书在线文档系统的五个技术重难点
前端·人工智能
jump_jump13 小时前
流式 HTML:从 htmx 片段装配到浏览器原生增量渲染
javascript·性能优化·前端工程化
红尘散仙13 小时前
想写一个像样的终端 App?试试把 React 的开发体验搬进 Rust TUI
前端·rust
袋鼠云数栈UED团队14 小时前
一套 Spec-First 的 AI 编程工作流
前端·人工智能
袋鼠云数栈前端14 小时前
一套 Spec-First 的 AI 编程工作流
前端·ai+
angerdream14 小时前
Android手把手编写儿童手机远程监控App之vue3 路由守卫
前端