Vue3.0寫自定義指令的簡單步驟記錄
阿新 • • 發佈:2021-06-28
前言
中提供了豐富的內建指令,如v-if,v-bind,v-on......,除此之外我們還可以通過Vue.directive({})或者directives:{}來定義指令
在開始學習之前我們應該理解,自定義指令的應用場景,任何功能的開發都是為了解決具體的問題的,
通過自定義指令,我們可以對DOM進行更多的底層操作,這樣不僅可以在某些場景下為我們提供快速解決問題的思路,而且讓我們對vue的底層有了進一步的瞭解
第一步
在main.
在src下簡歷對應的資料夾
import Directives from "@/Directives/index";// 自定義指令(@ 代表src) const app = createApp(App); app.use(Directives); app.mount("#app");
第二步
import copy from "./copy"; // 引入需要的指令 const directivesList = { copy // 掛載 }; const directives = { install: function (app) { Object.keys(directivesList).forEach((key) => { app.directive(key,directivesList[key]); // 註冊 }); } }; export default directives;// 丟擲
第三步
在copy.js 寫入我們的指令內容 Vue2 與Vue3只是一些生命週期函式修改
import { ElMessage } frowww.cppcns.comm "element-plus"; const copy = { mounted (el,{ value }) { el.$value = value; el.handler = () => { if (!el.$value) { // 值為空的時候,給出提示 ElMessage.warning({ message: "您好,複製的值不能為空。",type: "warning" }); return; } if (window.clipboardData) { http://www.cppcns.comwindow.clipboardData.setData("text",el.$value); } else { (function (content) { document.oncopy = function (e) { e.clipboardData.setData("text",content); e.preventDefault(); document.oncopy = null; }; })(el.$value); document.execCommand("Copy"); } ElMessage.success("複製成功"); }; // 繫結點選事件 el.addEventListener("click",el.handler); },beforeUpdate (el,{ value }) { el.$value = value; },unmounted (el) { el.removeEventListener("click",el.handler); } }; export default copy;
總結
到此這篇關於Vue3.0寫自定義指令的文章就介紹到這了,更多相關Vue3.0自定義指令內www.cppcns.com容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!