自定义指令

一、是什么?

1.概念

前端框架提供的扩展 DOM 行为的方式,允许开发者封装可复用的 DOM 操作逻辑,直接作用于 DOM 元素。相当于是自定义v-for的样子,而不用官方定义的指令。

2.类别
  • 全局指令:通过Vue.directive()(Vue2)或app.directive()(Vue3)注册,全项目可用;

  • 局部指令:在组件内通过directives选项声明,仅当前组件可用。

二、如何实现?

以v-focus为例

1.全局注册
  • 在main.js中注册
c 复制代码
import { createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 注册全局自定义指令:v-focus
app.directive('focus', {//自定义指令名
  // 指令钩子:元素挂载到DOM时触发
  mounted(el) {
    // el是指令绑定的DOM元素(此处为input/textarea)
    el.focus() // 原生DOM方法:获取焦点
  },
  // 可选:元素更新时触发(如弹窗从隐藏到显示)
  updated(el) {
    el.focus()
  }
})

app.mount('#app')

在App.vue中使用

c 复制代码
<template>
  <div class="demo">
    <h3>自定义指令:v-focus</h3>
    <!-- 绑定v-focus指令,输入框挂载后自动聚焦 -->
    <input v-focus type="text" placeholder="自动聚焦的输入框" />

    <!-- 进阶:弹窗内的输入框聚焦 -->
    <button @click="showModal = true">打开弹窗</button>
    <div class="modal" v-if="showModal">
      <input v-focus type="text" placeholder="弹窗内自动聚焦" />
      <button @click="showModal = false">关闭</button>
    </div>
  </div>
</template>
2.局部注册
  • 在使用的组件中声明即可

在App.vue中声明并使用

c 复制代码
<template>
  <input v-focus type="text" placeholder="局部指令自动聚焦" />
</template>

<script setup>
// 局部自定义指令
const vFocus = {
  mounted(el) {
    el.focus()
  }
}
</script>

三、应用实例

如何实现权限控制?

c 复制代码
<el-button
                  icon="el-icon-actualSearchForm"
                  type="primary"
                  size="mini"
                  @click="searchContractData"
                  v-loading.fullscreen.lock="operateLoading"
                  v-privilege="activeMenu + 'QUERY'"
                  >合同查询</el-button
                >
1.在method.js中定义权限指令
2.读取权限数据
bash 复制代码
this.activeMenu = window.top.localStorage.getItem('activeMenu')

四、拓展

这篇文章有很多自定义案例介绍,小伙伴们有还没看过瘾的来这篇瞧瞧:自定义指令案例

相关推荐
用户新23 分钟前
V8引擎 精品漫游指南--Ignition篇(下 一) 动态执行前的事情
前端·javascript
神探小白牙6 小时前
eCharts 多系列柱状图增加背景图
javascript·ecmascript·echarts
追风筝的人er8 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解
前端·vue.js·后端
编程老船长11 小时前
解决不同项目需要不同 Node.js 版本的问题
前端·vue.js
薛定猫AI12 小时前
【深度解析】Gemma Chat 本地 AI 编程 Agent:Electron + MLX + 开源模型的离线 Vibe Coding 实战
javascript·人工智能·electron
全栈前端老曹13 小时前
【前端地图】多地图平台适配方案——高德、百度、腾讯、Google Maps SDK 差异对比、封装统一地图接口
前端·javascript·百度·dubbo·wgs84·gcj-02·bd09
笑虾13 小时前
Win10 修改注册表 让鼠标悬停PNG上时 tip 始终显示分辨率
开发语言·javascript·ecmascript
xiaogg367813 小时前
spring oauth2 单点登录
java·vue.js·spring
雾岛听风69113 小时前
JavaScript基础语法速查手册
开发语言·前端·javascript
前端那点事13 小时前
Vue前端SEO优化全攻略(实操落地版,新手也能上手)
前端·vue.js