Vue 實現(xiàn)一個命令式彈窗組件功能
前言
在日常工作中彈窗組件是很常用的組件,但用得多還是別人的,空閑時間就自己來簡單實現(xiàn)一個彈窗組件
涉及知識點:extend、$mount、$el
使用方式:
this.$Confirm({ title:'自定義標題' }).then(res=>{ console.log(res) })
目錄結構
index.vue:組件布局、樣式、交互邏輯
index.js:掛載組件、暴露方法
知識點
在此之前,了解下涉及的知識點
1. extend
使用這個api,可以將引入的vue組件變成vue構造函數(shù),實例化后方便進行擴展
2. $mount
我們希望彈窗組件是在使用時才顯示出來,那么就需要動態(tài)的向body中添加元素。使用$mount方法可以手動掛載一個vue實例,和 extend 剛好搭配使用,這個也是彈窗組件命令式的關鍵。
3. $el
既然要添加dom元素,通過實例的$el屬性,正好可以取到dom元素,之后就是使用原生方法進行添加節(jié)點啦~
代碼實現(xiàn)
index.vue
<template> <div class="wrap"> <div class="main"> <div class="content"> {{title}} </div> <div class="btn-grounp"> <div class="btn cancel" @click="cancel">{{cancelText}}</div> <div class="btn confirm" @click="confirm">{{confirmText}}</div> </div> </div> </div> </template>
<script> export default { name:'', data () { return { title:'這是一個彈窗', confirmText:'確定', cancelText:'取消' }; }, methods: { show(cb){ typeof cb === 'function' && cb.call(this,this) return new Promise(resolve=>{ this.resolve = resolve }) }, confirm(){ this.resolve('confirm') this.hide() }, cancel(){ this.resolve('cancel') this.hide() }, hide(){ document.body.removeChild(this.$el) this.$destroy() } }, } </script>
<style scoped> .wrap{ position: fixed; top: 0; bottom:0; left:0; right:0; display:flex; justify-content: center; align-items: center; background: rgba(0,0,0,.3); } .main{ width: 30%; padding: 10px; background: #fff; box-shadow: 0 0 10px 1px #ddd; border-radius: 5px; } .content{ color:#424242; font-size: 20px; } .btn-grounp{ margin-top: 15px; display:flex; justify-content: flex-end; } .btn{ margin-left: 15px; padding: 5px 20px; border-radius: 5px; font-size: 16px; color:#fff; } .confirm{ background: lightblue; } .cancel{ background: lightcoral; } </style>
index.js
import Vue from 'vue' import comfirm from './index.vue' let newInstance = null //將vue組件變?yōu)闃嬙旌瘮?shù) let ConfirmConstructor = Vue.extend(comfirm) let init = (options)=>{ //實例化組件 newInstance = new ConfirmConstructor() //合并配置選項 Object.assign(newInstance,options) //加載dom document.body.appendChild(newInstance.$el) } let caller = (options)=>{ //options 為調用組件方法時傳入的配置選項 if(!newInstance){ init(options) } return newInstance.show(vm =>{newInstance = null}) } export default { install(vue){ vue.prototype.$Confirm = caller } }
main.js
上面我對外暴露的對象中含有install方法,這里可以使用Vue.use注冊組件(使用Vue.use后,會查找install方法進行調用),將組件調用方法掛載到Vue原型上。
import Confirm from './components/confirm' Vue.use(Confirm)
寫在最后
這個彈窗組件比較簡陋,還有很多地方可以完善,等有時間再搞了~
總結
以上所述是小編給大家介紹的Vue 實現(xiàn)一個命令式彈窗組件功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
相關文章
vue父組件監(jiān)聽子組件數(shù)據(jù)更新方式(hook)
這篇文章主要介紹了vue父組件監(jiān)聽子組件數(shù)據(jù)更新方式(hook),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08Vue實戰(zhàn)之vue登錄驗證的實現(xiàn)代碼
本篇文章主要介紹了Vue實戰(zhàn)之vue登錄的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10Vue監(jiān)聽一個數(shù)組id是否與另一個數(shù)組id相同的方法
今天小編就為大家分享一篇Vue監(jiān)聽一個數(shù)組id是否與另一個數(shù)組id相同的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09Vue3如何利用xlsx、xlsx-js-style導出Excel表格使用(適合新手)
在Vue項目中導出Excel表格是常見的功能,特別是在后臺管理系統(tǒng)中,為了方便用戶將大量數(shù)據(jù)保存為本地文件,這篇文章主要給大家介紹了關于Vue3如何利用xlsx、xlsx-js-style導出Excel表格使用的相關資料,需要的朋友可以參考下2024-06-06