Vue使用自定義指令打開dialog的實現(xiàn)方法
完整代碼見:https://codesandbox.io/
1. 寫一個dialog
既然要展示一個dialog,那么首先我們需要準(zhǔn)備一個dialog,供展示用,如下:實現(xiàn)了一個簡單的dialog,接收message和visible作為參數(shù)
<template> <el-dialog title="提示" :visible.sync="dialogVisible" width="30%" @close="handleClose" > <span>這是一段信息: {{ message }}</span> </el-dialog> </template> <script> export default { components: {}, props: { message: { type: String, default: "", }, visible: { type: Boolean, default: false, }, }, data() { return { dialogVisible: false, }; }, watch: { visible: { handler: function (v) { this.dialogVisible = v; }, immediate: true, }, }, methods: { handleClose() { this.$emit("close"); }, }, }; </script> <style></style>
2. 用自定義指令來控制dialog
彈窗有了,接下來實現(xiàn)個自定義指令來打開它
import Popup from "../components/Popup.vue"; import Vue from "vue"; /** * 打開彈窗 * @param {Object} binding */ const openDialog = (binding) => { const popupComponent = Vue.extend(Popup); const instance = new popupComponent({ propsData: { visible: true, message: binding.value, }, }); instance.$mount(); document.body.appendChild(instance.$el); instance.$on("close", () => { document.body.removeChild(instance.$el); instance.$destroy(); }); }; export default { bind(el, binding) { const handler = () => { openDialog(binding); }; el.addEventListener("click", handler); el._clickHandler = handler; }, unbind: function (el) { el.removeEventListener("click", el._clickHandler); }, };
3. 每次渲染新的dialog
如上述代碼,我們每次打開都會是一個新的彈窗,所以visible從外面?zhèn)魅肫鋵崨]什么存在的意義,所以我們將彈窗中的內(nèi)容再改造下,將visible相關(guān)的邏輯刪除,dialogVisible默認(rèn)為true即可。
4.使用該自定義指令
<template> <div id="app"> <div v-popup="msg">點擊打開彈窗</div> </div> </template> <script> import popup from "./directives/popup"; export default { name: "App", directives: { popup, }, data() { return { msg: "傳遞的消息", }; }, }; </script>
效果圖示:
到此這篇關(guān)于Vue使用自定義指令打開dialog的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)Vue打開dialog內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
VUE使用router.push實現(xiàn)頁面跳轉(zhuǎn)和傳參方式
這篇文章主要介紹了VUE使用router.push實現(xiàn)頁面跳轉(zhuǎn)和傳參方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01vue項目如何從session中獲取對象,并且使用里面的屬性
這篇文章主要介紹了vue項目如何從session中獲取對象,并且使用里面的屬性問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12vue中實現(xiàn)監(jiān)聽數(shù)組內(nèi)部元素
這篇文章主要介紹了vue中實現(xiàn)監(jiān)聽數(shù)組內(nèi)部元素方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08Vite結(jié)合Vue刪除指定環(huán)境的console.log問題
這篇文章主要介紹了Vite結(jié)合Vue刪除指定環(huán)境的console.log問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03