這篇文章將為大家詳細講解有關使用Vue怎么實現(xiàn)一個命令式彈窗組件,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
公司主營業(yè)務:網(wǎng)站制作、成都網(wǎng)站設計、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出滄縣免費做網(wǎng)站回饋大家。
使用方式:
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
{{title}}{{cancelText}}{{confirmText}}
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)一個命令式彈窗組件就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。