Vue常用自定義指令-積累的魅力【VUE】

前言

  • 在【自定義指令—v2與v3之間的區別【VUE基礎】一文中,整理了自定義指令部分vue2vue3 兩個版本的區別,有興趣的伙伴或者針對自定義部分比較迷茫的伙伴可以跳轉看一下。
  • 此次主要介紹一些自己積累的一些自定義指令的代碼,與大家一起分享。
  • 后續,開發中如果有新的比較有意思的部分,會同步更新。

文章目錄

    • 前言
    • 1.基本介紹
        • 1-1.基本概念
        • 1-2.核心特征
        • 1-3.實現方式
    • 2.常用自定義指令代碼分享
      • 2-1.搜索文本高亮
        • 解釋說明:
        • 代碼分享:
      • 2-2.頁面拖拽
        • 解釋說明:
        • 代碼分享:
      • 2-3.自動聚焦(v2 和 v3)
    • 3.參考資源

1.基本介紹

當前簡單介紹一下自定義指令,如需了解更多關于自定義指令的基礎知識,【點擊跳轉自定義指令基礎】

1-1.基本概念
  • 定義:自定義指令是Vue提供的擴展機制,用于封裝對DOM元素的底層操作邏輯
  • 與內置指令區別:內置指令如v-if/v-for可直接使用,而自定義指令需要開發者顯式注冊
  • 適用場景:主要用于需要直接操作DOM元素的復用邏輯
1-2.核心特征
  • 命名規范:
  • 必須以v-開頭
  • <script setup>中可使用駝峰命名變量自動轉換
  • 生命周期鉤子:
  • mounted:元素插入父節點時調用
  • updated:組件VNode更新時調用
  • unmounted:元素從父節點移除時調用
  • 參數傳遞:
  • el:指令綁定的DOM元素
  • binding:包含value/oldValue等屬性的對象
1-3.實現方式

1.全局注冊

app.directive('highlight',{mounted(el,binding) {el.focus()}
})

2.局部注冊,即組件中注冊

directives: {highlight: {mounted(el,binding) {el.focus()}}

2.常用自定義指令代碼分享

2-1.搜索文本高亮

展示效果:
在這里插入圖片描述

解釋說明:
  • 效果:
    • 搜索到的結果列表中匹配搜索關鍵字,并高亮展示;
  • 實現方式:
    • 獲取元素節點,以及節點中的數據
    • 使用正則去匹配對應字段;
    • 生成新的元素,去替換匹配的部分。
  • 使用場景:搜索結果展示,突然搜索關鍵字
  • 使用注意:
    • 當前這種方式因為執行在mounted 鉤子函數中,只在節點加載第一次時執行,所以要想實現如上所示,就使用了定時器的異步加載,先清除,再重新過濾結果,重新加載。
  • 如果有更好的辦法,可以留言,歡迎指正。
代碼分享:
  • highlight.js
	export const highLight = {mounted(el, binding) {const { value } = binding;const regExp = new RegExp(value, "gi");const highLightText = (node) => {if (node.nodeType === 3) {const text = node.nodeValue;const newNode = document.createElement("span");newNode.innerHTML = text.replace(regExp, `<span style="color: red;">$&</span>`);node.parentNode.replaceChild(newNode, node);} else {const childNodes = node.childNodes;childNodes.forEach((child) => {highLightText(child);});}}highLightText(el);}};
  • main.js 中全局注冊
import './assets/main.css'
import { createApp } from 'vue'
import App from './App.vue'
import { highLight2 } from './utils/highLight.js'
const app = createApp(App)
app.directive('highlight', highLight2)
app.mount('#app')
  • 使用組件(只是簡單的使用例子,參考用。)
<script setup>
import {ref} from 'vue';
let search = ref('')
let testData= ref([{id:1, name:'張三'},{id:2, name:'測試'},{id:3, name:'李四'},{id:4, name:'張四'},{id:5, name:'李三'},{id:6, name:'趙四'},{id:7, name:'趙二'},{id:8, name:'唐三'},{id:9, name:'唐五'},
])
let resultData=ref([])function inputFun(){resultData.value = []//使用settimeout 的異步,使得代碼執行有點時間差。//感覺不太靠譜setTimeout(() => {resultData.value = testData.value.filter((item) => {return item.name.includes(search.value)})}, 0)
}
</script><template><div><el-input v-model="search" style="width: 240px" placeholder="Please input" @input="inputFun"/><ul>  <li v-for="item in resultData" :key="item.id"><span v-highlight="search">{{item.name}}</span></li></ul></div></template>
<style lang="scss" scoped>
div{}
</style>

2-2.頁面拖拽

展示動畫效果如下:
在這里插入圖片描述

解釋說明:
  • 實現效果
    • 可以在屏幕中拖拽到任意位置;
  • 實現方式:
    • 通過position定位元素,
    • 通過鼠標事件,獲取鼠標點擊位置,獲取元素的寬高,元素在屏幕中的位置
    • 通過這些數值計算元素的lefttop;
  • 使用場景:瀏覽器中的智能機器人圖標等,獨立存在在瀏覽器中的元素。
  • 可優化:
    • 對于瀏覽器上方的判斷邊界不是很完善。
代碼分享:
  • draggable.js
function draggable(el, binding) {   let startMX,startMY;let startOL,startOT;el.style.cursor = 'move';//給元素幫定鼠標事件el.addEventListener('mousedown', (e) => {startMX = e.clientX;startMY = e.clientY;startOL = el.offsetLeft;startOT = el.offsetTop;document.addEventListener('mousemove', dragMove);document.addEventListener('mouseup', dragEnd);});// 鼠標移動事件,處理鼠標移動位置const dragMove = (e) => {const moveX = e.clientX ;const moveY = e.clientY ;const left = moveX - startMX + startOL;const top = moveY - startMY + startOT;let docH = window.innerHeight;let docW = window.innerWidth;let elW = el.getBoundingClientRect().width;let elH = el.getBoundingClientRect().height;let newLeft = left>0 ? left : 0;let newTop = top>0 ? top : 0;newLeft = left>docW - elW ? docW - elW : left;newTop = top>docH - elH ? docH - elH : top;el.style.left = `${newLeft}px`;el.style.top = `${newTop}px`;};//鼠標事件結束,清除事件const dragEnd = () => {document.removeEventListener('mousemove', dragMove);document.removeEventListener('mouseup', dragEnd);}
}export default {install(app) {app.directive('draggable', {mounted(el, binding) {draggable(el, binding);},updated(el, binding) {draggable(el, binding);},});}
};
  • draggable.vue(只是簡單的使用例子,參考用。)
<script setup>
</script><template><div class="app"><div class="draggable-box" v-draggable> </div></div>
</template>
<style lang="scss" scoped>
.draggable-box{background: #f00;width: 100px;height: 100px;position: absolute;
}
.app{background: #333;width: 100vw;height: 100vh;position: relative;
}
</style>

2-3.自動聚焦(v2 和 v3)

效果展示:
在這里插入圖片描述

  • vue2自動聚焦
//vue2
Vue.directive('focus', {inserted: function (el) {if (el.focus)el.focus();const input = el.querySelector('input');if (input)input.focus();}
});
  • vue3自動聚焦
//vue3
app.directive('focus', {mounted(el) {if (el.focus)el.focus();const input = el.querySelector('input');if (input)input.focus();},
});

3.參考資源

  1. vue3.js官方網站:https://cn.vuejs.org/
  2. vue2.js官方網站:https://v2.cn.vuejs.org/

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/84200.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/84200.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/84200.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【mysql】mysql的高級函數、高級用法

mysql是最常用的數據庫之一&#xff0c;常見的函數用法大家應該都很熟悉&#xff0c;本文主要例舉一些相對出現頻率比較少的高級用法 (注&#xff1a;需注意mysql版本&#xff0c;大部分高級特性都是mysql8才有的) 多值索引與虛擬列 主要是解決字符串索引問題&#xff0c;光說…

C#日期和時間:DateTime轉字符串全面指南

C#日期和時間&#xff1a;DateTime轉字符串全面指南 在 C# 開發中&#xff0c;DateTime類型的時間格式化是高頻操作場景。無論是日志記錄、數據持久化&#xff0c;還是接口數據交互&#xff0c;合理的時間字符串格式都能顯著提升系統的可讀性和兼容性。本文將通過 20 實戰示例…

Canvas設計圖片編輯器全講解(一)Canvas基礎(萬字圖文講解)

一、前序 近兩年AI發展太過迅速&#xff0c;各類AI產品層出不窮&#xff0c;AI繪圖/AI工作流/AI視頻等平臺的蓬勃發展&#xff0c;促使圖片/視頻等復雜內容的創作更加簡單&#xff0c;讓更多普通人有了圖片和視頻創作的機會。另一方面用戶內容消費也逐漸向圖片和視頻傾斜。在“…

Javase易混點專項復習02_static關鍵字

1. static關鍵字1.1概述1.2修飾一個成員變量例&#xff1a;1.2.1靜態屬性與非靜態屬性示例及內存圖對比 1.3修飾一個方法&#xff08;靜態方法&#xff09;1.4.static修飾成員的訪問特點總結1.5動態代碼塊和靜態代碼塊1.5.1動態代碼塊1.5.2 靜態代碼塊 1.6帶有繼承的對象創建過…

C++滑動門問題(附兩種方法)

題目如下&#xff1a; 滑動窗口 - 題目 - Liusers OJ ——引用自OJ網站 方法如下&#xff1a; 1.常規思想 #include<bits/stdc.h> using namespace std; int main() {int n,k;int a[110];cin>>n>>k;for(int i0;i<n;i){cin>>a[i];}for(int i0;i…

mysql連接池druid監控配置

文章目錄 前置依賴啟用配置訪問監控一些問題 前置 連接池有很多類型&#xff0c;比如 c3p0&#xff0c;比如 hikariCP&#xff0c;比如 druid。c3p0 一些歷史項目可能用的比較多&#xff0c;hikariCP 需要高性能的項目比較多&#xff0c;druid 性能也很好&#xff0c;而且還提…

Jetson系統燒錄與環境配置全流程詳解(含驅動、GCC、.Net設置)

Jetson系統燒錄與環境配置全流程詳解&#xff08;含驅動、GCC、.Net設置&#xff09; 目錄1. 準備工作與工具安裝1.1 主機系統要求1.2 安裝 SDK Manager 2. JetPack 系統燒錄流程2.1 Jetson 進入恢復模式2.2 使用 SDK Manager 燒錄 JetPack 3. Jetson 系統基礎設置4. 配置 .Net…

分布式緩存:緩存的三種讀寫模式及分類

文章目錄 緩存全景圖Pre緩存讀寫模式概述1. Cache Aside&#xff08;旁路緩存&#xff09;工作流程優缺點 2. Read/Write Through&#xff08;讀寫穿透&#xff09;工作流程優缺點典型場景 3. Write Behind Caching&#xff08;異步寫回&#xff09;工作流程優缺點典型場景 緩存…

Ntfs!FindFirstIndexEntry函數中ReadIndexBuffer函數的作用是新建一個Ntfs!_INDEX_LOOKUP_STACK結構

第一部分&#xff1a; 0: kd> kc # 00 Ntfs!FindFirstIndexEntry 01 Ntfs!NtfsRestartIndexEnumeration 02 Ntfs!NtfsQueryDirectory 03 Ntfs!NtfsCommonDirectoryControl 04 Ntfs!NtfsFsdDirectoryControl 05 nt!IofCallDriver 06 nt!IopSynchronousServiceTail 07 nt!Nt…

5.24 note

笛卡爾積(?選擇條件 select a.student_name as member_A, b.student_name as member_B, c.student_name as member_C from schoola as a join schoolb as b join schoolc as c where a.student_name ! b.student_name and a.student_name !…

為什么需要在循環里fetch?

假設有多個設備連接在后端,數量不定,需要按個讀回狀態,那么就要在循環里fetch了. 此函數非常好用,來自于國內一個作者,時間久了,忘記了來源,抱歉. export default async function fetchWithTimeout(resource, options {}) {const { timeout 1000 } options;const controll…

不同凈化技術(靜電 / UV / 濕式)的性能對比研究

在餐飲油煙和工業廢氣治理領域&#xff0c;油煙凈化技術的選擇至關重要。目前&#xff0c;靜電、UV 光解、濕式洗滌是市場上應用較為廣泛的三種凈化技術。它們憑借不同的工作原理和技術特性&#xff0c;在凈化效率、能耗、適用場景等方面展現出各自的優勢與局限。本文將從多個維…

Ubuntu 22.04上升級npm版本

如果使用NVM安裝Node.js npm會自動包含&#xff0c;但版本可能不是最新的。你可以選擇升級&#xff1a; # 檢查當前版本 npm --version# 升級到最新版本 npm install -g npmlatest# 或者升級到特定版本 npm install -g npm9.8.1如果使用其他方法安裝Node.js 通常Node.js安裝…

項目管理進階:111頁 詳解華為業務變革框架及戰略級項目管理【附全文閱讀】

BTMS 是一套集成管理系統框架&#xff0c;涵蓋變革規劃、項目執行、實施及生命周期管理等多個關鍵環節。在規劃階段&#xff0c;通過全面收集需求、深入分析現狀&#xff0c;制定出符合業務戰略的年度規劃&#xff0c;明確變革舉措和項目清單。 解決方案開發的 PMOP 流程&#…

java基礎知識回顧1(可用于Java基礎速通)考前,面試前均可用!

目錄 一、初識java 二、基礎語法 1.字面量 2.變量 3.關鍵字 4.標識符 聲明&#xff1a;本文章根據黑馬程序員b站教學視頻做的筆記&#xff0c;可對應課程聽&#xff0c;課程鏈接如下: 02、Java入門&#xff1a;初識Java_嗶哩嗶哩_bilibili 一、初識java Java是美國 sun 公…

Linux下MySQL的安裝與使用

1 安裝前說明 1.1 Linux系統及工具的準備 安裝并啟動好兩臺虛擬機&#xff1a;CentOS 7 掌握克隆虛擬機的操作 mac地址主機名ip地址UUID 安裝有 Xshell 和 Xftp 等訪問 CentOS 系統的工具 CentOS6 和 CentOS7 在 MySQL 的使用中的區別 防火墻&#xff1a;6是iptables&am…

在react項目中使用andt日期組件,選擇周和季度,直接獲取所對應的日期區間

在react項目中使用andt日期組件&#xff0c;選擇周和季度&#xff0c;直接獲取所對應的日期區間 import { DatePicker, Space } from antd; import React from react; const onChange (date, dateString) > {console.log(date,dateString) }; const onChangeweek (date, …

數字信號處理大實驗2 利用FFT估計信號的頻率

目錄 3.1 實驗目的 3.2 實驗內容與要求 3.3 實驗原理 3.3.1 基于時域求導-頻域乘法的n階導數積分法 3.3.2 基于頻域卷積的雙/多譜線插值法 3.3.3 基于譜峰和滑動平均的多譜線綜合插值方法 3.3.4 基于相鄰顯著譜線的滑動平均綜合插值方法 3.3.5 基于&#xff08;2&#…

【Java】Java元注解

Target(ElementType.METHOD) Retention(value RetentionPolicy.RUNTIME) public interface OperatorLog {String source() default "WEB"; //日志操作來源 默認是web&#xff0c;還有socket的String model() default ""; //操作模塊 }這個代碼中的 Target…

阿里云百煉(1) : 阿里云百煉應用問答_回答圖片問題_方案1_提問時上傳圖片文件

直接用于拍照答題不大理想, 可能適用其他用途, 更好的方案: 阿里云百煉(1) : 阿里云百煉應用問答_回答圖片問題_方案2_提取題目再提問-CSDN博客 1.實現代碼 package cn.nordrassil.ly.test.拍照答題;import com.alibaba.dashscope.app.Application; import com.alibaba.dashsc…