這篇文章將為大家詳細(xì)講解有關(guān)Vue中Toast的示例分析,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)長(zhǎng)期為1000多家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為雙橋企業(yè)提供專業(yè)的成都網(wǎng)站制作、網(wǎng)站建設(shè),雙橋網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。一、效果圖
二、說(shuō)明
這類提示框組件我們通常都會(huì)直接在 JS 代碼中進(jìn)行調(diào)用。像下面這樣:
this.$toast('別點(diǎn)啦,到頭啦!')
但看到網(wǎng)上大多數(shù)還是通過(guò) component 方式實(shí)現(xiàn)的,這樣的話我們?cè)谑褂玫臅r(shí)候還要在 DOM 中放置一個(gè)組件元素,然后通過(guò)一個(gè)變量來(lái)控制它的顯示隱藏,這樣使用起來(lái)非常的不方便。那么有什么方法可以不用在 DOM 中手動(dòng)放置組件元素就可以直接調(diào)用呢?答案就是 Vue.extend。通過(guò) Vue.extend 方式實(shí)現(xiàn)的組件,需要兩個(gè)文件,一個(gè)是 .vue 文件,另外一個(gè)就是管理 .vue 的 .js 文件。具體代碼如下:
三、代碼
Toast.vue 文件代碼
{{ message }}
Toast.js 文件代碼
import Vue from 'vue' import Toast from '@/components/layer/Toast.vue' let ToastConstructor = Vue.extend(Toast) // 構(gòu)造函數(shù) let instance // 實(shí)例對(duì)象 let seed = 1 // 計(jì)數(shù) const ToastDialog = (options = {}) => { if (typeof options === 'string') { options = { message: options } } let id = `toast_${seed++}` instance = new ToastConstructor({ data: options }) instance.id = id instance.vm = instance.$mount() document.body.appendChild(instance.vm.$el) instance.vm.visible = true instance.dom = instance.vm.$el instance.dom.style.zIndex = 999 + seed return instance.vm } export default ToastDialog
四、使用
首先在 main.js 中引入 Toast.js 并掛載到vue原型上,如下圖:
其次,在代碼中使用
this.$toast('別點(diǎn)啦,到頭啦!')
關(guān)于“Vue中Toast的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。