「Vue3系列」Vue3指令

简介: Vue 3 指令是 Vue 模板中用于与 DOM 进行交互的特殊属性。指令以 `v-` 为前缀,后面跟着指令名称。Vue 3 提供了一系列内置指令,同时你也可以创建自定义指令

一、Vue3 指令

Vue 3 指令是 Vue 模板中用于与 DOM 进行交互的特殊属性。指令以 v- 为前缀,后面跟着指令名称。Vue 3 提供了一系列内置指令,同时你也可以创建自定义指令。下面是一些 Vue 3 中常用的内置指令:

  1. v-bind
    用于属性绑定,将表达式的结果绑定到一个元素的属性上。
<img v-bind:src="imageSrc" alt="Vue logo">

简写形式为 :

<img :src="imageSrc" alt="Vue logo">
  1. v-model
    用于在表单元素上创建双向数据绑定。
<input v-model="message" placeholder="edit me">
<p>Message is: {
  { message }}</p>
  1. v-on
    用于监听 DOM 事件,并在触发时执行一些 JavaScript 代码。
<button v-on:click="increment">Increment</button>

简写形式为 @

<button @click="increment">Increment</button>
  1. v-ifv-else-ifv-else
    用于条件渲染。根据表达式的值来决定是否渲染一个元素。
<div v-if="type === 'A'">
  Render A
</div>
<div v-else-if="type === 'B'">
  Render B
</div>
<div v-else>
  Render Others
</div>
  1. v-for
    用于列表渲染。基于源数据多次渲染一个元素或模板块。
<div v-for="item in items" :key="item.id">
  {
  { item.text }}
</div>
  1. v-show
    根据表达式的值的真假,切换元素的 display CSS 属性。
<p v-show="isVisible">Hello when visible</p>
  1. v-pre
    跳过这个元素和它的子元素的编译过程。可以用来显示原始的 Mustache 标签。
<div v-pre>
  {
  { this will not be compiled }}
</div>
  1. v-cloak
    这个指令保持在元素上直到关联实例结束编译。和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Mustache 标签直到实例准备完毕。
<div v-cloak>
  {
  { message }}
</div>
[v-cloak] {
   
  display: none;
}
  1. v-once
    将元素和组件标记为只渲染一次。
<span v-once>This will only be rendered once.</span>
  1. v-text
    更新元素的 textContent

    <span v-text="message"></span>
    
  2. v-html
    更新元素的 innerHTML

    <div v-html="htmlContent"></div>
    

除了这些内置指令,Vue 3 还允许你注册自定义指令。自定义指令可以扩展 Vue 的基本功能,用于执行复杂的 DOM 操作或处理特定的业务逻辑。

二、注册-自定义指令

注册自定义指令有两种方式:全局注册和局部注册。全局注册的指令可以在任何 Vue 实例中使用,而局部注册的指令只能在特定的 Vue 实例或组件中使用。

注册自定义指令的基本语法如下:

// 全局注册
Vue.directive('focus', {
   
  // 当被绑定的元素插入到 DOM 中时……
  inserted: function (el) {
   
    // 聚焦元素
    el.focus()
  }
})

// 局部注册
const app = Vue.createApp({
   })

app.directive('focus', {
   
  // 定义指令
})

app.mount('#app')

三、常见自定义指令

在 Vue 3 中,自定义指令允许你注册一些可以在模板中重复使用的行为。这些行为可以附加到任何元素上,并在元素的特定生命周期钩子中执行自定义逻辑。以下是一些 Vue 3 中常见的自定义指令及其案例代码:

1. 聚焦指令(v-focus)

当页面加载时,自动将焦点聚焦到指定的元素上。

// main.js 或其他初始化文件
import {
    createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 全局注册自定义指令 v-focus
app.directive('focus', {
   
  mounted(el) {
   
    el.focus()
  }
})

app.mount('#app')
<!-- App.vue -->
<template>
  <div>
    <input v-focus type="text" placeholder="自动聚焦到这个输入框">
  </div>
</template>

2. 高亮指令(v-highlight)

将匹配的文本在元素中进行高亮显示。

// main.js 或其他初始化文件
import {
    createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 全局注册自定义指令 v-highlight
app.directive('highlight', {
   
  beforeMount(el, binding) {
   
    el.innerHTML = el.innerHTML.replace(new RegExp(binding.value, 'gi'), function(matched) {
   
      return `<span style="background-color: yellow;">${
     matched}</span>`
    })
  }
})

app.mount('#app')
<!-- App.vue -->
<template>
  <div>
    <p v-highlight="'vue'">在这里,'vue' 会被高亮显示。</p>
  </div>
</template>

3. 防抖指令(v-debounce)

对事件处理函数进行防抖处理,减少不必要的计算或请求。

// main.js 或其他初始化文件
import {
    createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 全局注册自定义指令 v-debounce
app.directive('debounce', {
   
  beforeMount(el, binding) {
   
    let timer = null
    el.addEventListener('input', function() {
   
      clearTimeout(timer)
      timer = setTimeout(() => {
   
        binding.value()
      }, binding.arg || 500)
    })
  }
})

app.mount('#app')
<!-- App.vue -->
<template>
  <div>
    <input v-debounce="search" type="text" placeholder="防抖处理,输入后延迟500ms执行">
  </div>
</template>

<script>
export default {
    
  methods: {
    
    search() {
    
      console.log('执行搜索')
    }
  }
}
</script>

4. 限制输入指令(v-limit)

限制输入框中字符的数量。

// main.js 或其他初始化文件
import {
    createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 全局注册自定义指令 v-limit
app.directive('limit', {
   
  mounted(el, binding) {
   
    el.addEventListener('input', function() {
   
      if (el.value.length > binding.value) {
   
        el.value = el.value.slice(0, binding.value)
      }
    })
  }
})

app.mount('#app')
<!-- App.vue -->
<template>
  <div>
    <input v-limit="10" type="text" placeholder="最多输入10个字符">
  </div>
</template>

使用注意事项

  • 在使用自定义指令时,要确保指令名称不与 Vue 的内置指令名称冲突。
  • 在自定义指令的钩子函数中,el 参数是绑定指令的元素,binding 参数是一个对象,包含了一些有用的属性,如 name(指令名)、value(指令的绑定值)、oldValue(指令绑定的前一个值)、arg(指令的参数)、modifiers(包含修饰符的对象)。
  • 如果需要监听多个事件或进行更复杂的 DOM 操作,可以考虑

四、相关链接

  1. Vue3官方地址
  2. Vue3中文文档
相关文章
|
6月前
|
JavaScript 前端开发 安全
Vue 3
Vue 3以组合式API、Proxy响应式系统和全面TypeScript支持,重构前端开发范式。性能优化与生态协同并进,兼顾易用性与工程化,引领Web开发迈向高效、可维护的新纪元。(238字)
874 139
|
11月前
|
缓存 JavaScript PHP
斩获开发者口碑!SnowAdmin:基于 Vue3 的高颜值后台管理系统,3 步极速上手!
SnowAdmin 是一款基于 Vue3/TypeScript/Arco Design 的开源后台管理框架,以“清新优雅、开箱即用”为核心设计理念。提供角色权限精细化管理、多主题与暗黑模式切换、动态路由与页面缓存等功能,支持代码规范自动化校验及丰富组件库。通过模块化设计与前沿技术栈(Vite5/Pinia),显著提升开发效率,适合团队协作与长期维护。项目地址:[GitHub](https://github.com/WANG-Fan0912/SnowAdmin)。
1252 5
|
6月前
|
缓存 JavaScript 算法
Vue 3性能优化
Vue 3 通过 Proxy 和编译优化提升性能,但仍需遵循最佳实践。合理使用 v-if、key、computed,避免深度监听,利用懒加载与虚拟列表,结合打包优化,方可充分发挥其性能优势。(239字)
485 1
|
7月前
|
开发工具 iOS开发 MacOS
基于Vite7.1+Vue3+Pinia3+ArcoDesign网页版webos后台模板
最新版研发vite7+vue3.5+pinia3+arco-design仿macos/windows风格网页版OS系统Vite-Vue3-WebOS。
755 11
|
6月前
|
JavaScript 安全
vue3使用ts传参教程
Vue 3结合TypeScript实现组件传参,提升类型安全与开发效率。涵盖Props、Emits、v-model双向绑定及useAttrs透传属性,建议明确声明类型,保障代码质量。
543 0
|
8月前
|
缓存 前端开发 大数据
虚拟列表在Vue3中的具体应用场景有哪些?
虚拟列表在 Vue3 中通过仅渲染可视区域内容,显著提升大数据列表性能,适用于 ERP 表格、聊天界面、社交媒体、阅读器、日历及树形结构等场景,结合 `vue-virtual-scroller` 等工具可实现高效滚动与交互体验。
825 1
|
8月前
|
缓存 JavaScript UED
除了循环引用,Vue3还有哪些常见的性能优化技巧?
除了循环引用,Vue3还有哪些常见的性能优化技巧?
438 0
|
9月前
|
JavaScript
vue3循环引用自已实现
当渲染大量数据列表时,使用虚拟列表只渲染可视区域的内容,显著减少 DOM 节点数量。
204 0
|
11月前
|
JavaScript API 容器
Vue 3 中的 nextTick 使用详解与实战案例
Vue 3 中的 nextTick 使用详解与实战案例 在 Vue 3 的日常开发中,我们经常需要在数据变化后等待 DOM 更新完成再执行某些操作。此时,nextTick 就成了一个不可或缺的工具。本文将介绍 nextTick 的基本用法,并通过三个实战案例,展示它在表单验证、弹窗动画、自动聚焦等场景中的实际应用。
1051 17
|
10月前
|
JavaScript API 开发者
Vue框架中常见指令的应用概述。
通过以上的详细解析,你应该已经初窥Vue.js的指令的威力了。它们是Vue声明式编程模型的核心之一,无论是构建简单的静态网站还是复杂的单页面应用,你都会经常用到。记住,尽管Vue提供了大量预定义的指令,你还可以创建自定义指令以满足特定的需求。为你的Vue应用程序加上这些功能增强器,让编码变得更轻松、更愉快吧!
187 1