- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > web開(kāi)發(fā) > JavaScript >
- Vue3.0寫(xiě)自定義指令的簡(jiǎn)單步驟記錄
vue中提供了豐富的內置指令,如v-if,v-bind,v-on......,除此之外我們還可以通過(guò)Vue.directive({})或者directives:{}來(lái)定義指令
在開(kāi)始學(xué)習之前我們應該理解,自定義指令的應用場(chǎng)景,任何功能的開(kāi)發(fā)都是為了解決具體的問(wèn)題的,
通過(guò)自定義指令,我們可以對DOM進(jìn)行更多的底層操作,這樣不僅可以在某些場(chǎng)景下為我們提供快速解決問(wèn)題的思路,而且讓我們對vue的底層有了進(jìn)一步的了解
在main.js
在src下簡(jiǎn)歷對應的文件夾
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 寫(xiě)入我們的指令內容 Vue2 與Vue3只是一些生命周期函數修改
import { ElMessage } from "element-plus"; const copy = { mounted (el, { value }) { el.$value = value; el.handler = () => { if (!el.$value) { // 值為空的時(shí)候,給出提示 ElMessage.warning({ message: "您好,復制的值不能為空。", type: "warning" }); return; } if (window.clipboardData) { window.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("復制成功"); }; // 綁定點(diǎn)擊事件 el.addEventListener("click", el.handler); }, beforeUpdate (el, { value }) { el.$value = value; }, unmounted (el) { el.removeEventListener("click", el.handler); } }; export default copy;
到此這篇關(guān)于Vue3.0寫(xiě)自定義指令的文章就介紹到這了,更多相關(guān)Vue3.0自定義指令內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站