封裝一個(gè)vue中也可使用的uniapp的全局彈窗組件(任何頁(yè)面都可以彈出)
效果圖:
場(chǎng)景:
當(dāng)你對(duì)接websocket時(shí),或者輪詢也好,你需要獲取到最新的信息,并且在任何頁(yè)面彈出一個(gè)組件進(jìn)行后續(xù)操作
思路:
1、先封裝好要彈出的公共組件
2、向vue原型上掛載全局方法,拿到組件真實(shí)dom,從而對(duì)組件進(jìn)行顯隱操作
第一步:
創(chuàng)建一個(gè)公共組件,以下是組件全部的結(jié)構(gòu)及樣式,你需要把html中的兩個(gè)image標(biāo)簽的路徑換掉或者直接注釋掉也行,html 和 css就不做解釋了
invite.vue
<template> <div class="invite-box"> <view class="center-box"> <image class="logo" src="/static/invite-logo.png"></image> <image class="close" src="/static/close.png" v-on:click="$closeInvite"></image> <view class="title">邀請(qǐng)函</view> <view class="content">您好!您的朋友xxx邀請(qǐng)您對(duì)<text>“為什么小朋友到了一定年齡需要打疫苗?”</text>進(jìn)行專家答疑,您是否接受?</view> <view class="btn-group"> <view class="invite-specia">邀請(qǐng)專家</view> </view> </view> </div> </template> <script> export default { name: 'invite', props: { _specia: String }, data() { return {} }, mounted() { console.log('this.specia', this._specia); } } </script> <style scoped lang='scss'> .invite-box { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(0,0,0,0.5); z-index: 9999; .center-box { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 622rpx; padding: 32rpx; border-radius: 16rpx; opacity: 1; background: rgba(255,255,255,1); .logo { position: absolute; top: -48rpx; left: 50%; transform: translateX(-50%); width: 136rpx; height: 144rpx; } .close { position: absolute; top: 24rpx; right: 24rpx; width: 48rpx; height: 48rpx; } .title { margin-top: 66rpx; text-align: center; color: rgba(0,0,0,1); font-size: 36rpx; font-weight: 500; font-family: "PingFang SC"; letter-spacing: 0.6rpx; } .content { margin: 40rpx 0; font-size: 26rpx; font-family: "PingFang SC"; letter-spacing: 0.6rpx; color: #343434; text { font-size: 32rpx; letter-spacing: 0.6rpx; color: rgba(69,108,255,1); } } .btn-group { display: flex; justify-content: center; padding: 0 16rpx; .invite-specia { width: 526rpx; height: 88rpx; line-height: 88rpx; border-radius: 16rpx; text-align: center; background: linear-gradient(-46.8deg, rgba(63,101,255,1) 0%, rgba(97,141,255,1) 100%); color: #fff; } } } } </style>
第二步:
注冊(cè)一個(gè)全局函數(shù),使用 Vue.prototype,首先創(chuàng)建一個(gè)js文件來(lái)存放你的全局方法,之后在main.js中引入掛載
以下代碼中幾個(gè)關(guān)鍵點(diǎn):
1、install,參數(shù)可以拿到Vue函數(shù),等價(jià)于 main.js 中 import 進(jìn)來(lái)的 Vue
2、Vue.extend(Invite),這里可以看到 Invite 是我導(dǎo)入的組件實(shí)例對(duì)象,該方法傳入組件實(shí)例對(duì)象可以返回給你該組件的實(shí)例構(gòu)造器,方便我們后續(xù)多次構(gòu)建并操作該組件
3、instance._props._specia = params,這里只是向新構(gòu)建的組件內(nèi)傳遞一個(gè)props參數(shù)
4、instance.vm = instance.$mount(),掛載模板,生成真實(shí)dom,作用和$el一致
5、invite-box是組件最外層盒子的類名
6、setTimeout,因?yàn)橐砑拥阶詈?,需要異步添?/p>
invite.js
import Invite from '../components/invite.vue' export default { install(Vue) { const Profile = Vue.extend(Invite) // 彈出邀請(qǐng) Vue.prototype.$openInvite = function(params) { const instance = new Profile() instance._props._specia = params instance.vm = instance.$mount() const InviteEle = document.body.lastElementChild if(InviteEle.className === 'invite-box') return setTimeout(() => document.body.appendChild(instance.vm.$el)) return instance } // 關(guān)閉邀請(qǐng) Vue.prototype.$closeInvite = function() { const instance = new Profile() instance.vm = instance.$mount() const InviteEle = document.body.lastElementChild if(InviteEle.className !== 'invite-box') return document.body.removeChild(InviteEle) return instance } } }
main.js
// 導(dǎo)入invite.js import invite from './utils/invite' // 安裝插件 Vue.use(invite)
第三部:使用
在你任何組件內(nèi)調(diào)用 this.$openInvite() 即可彈出組件,調(diào)用 this.$closeInvite()即可關(guān)閉組件
以上就是整個(gè)過(guò)程,是不是很好用呢
總結(jié)
到此這篇關(guān)于封裝一個(gè)vue中也可使用的uniapp的全局彈窗組件的文章就介紹到這了,更多相關(guān)uniapp全局彈窗組件封裝內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
瀏覽器圖片選擇預(yù)覽、旋轉(zhuǎn)、批量上傳的JS代碼實(shí)現(xiàn)
這篇文章主要介紹了瀏覽器圖片選擇預(yù)覽、旋轉(zhuǎn)、批量上傳的JS代碼實(shí)現(xiàn),有需要的朋友可以參考一下2013-12-12echarts實(shí)現(xiàn)雷達(dá)圖的詳細(xì)步驟
這篇文章主要給大家介紹了關(guān)于echarts實(shí)現(xiàn)雷達(dá)圖的詳細(xì)步驟,雷達(dá)圖(Radar?Chart)是一種信息豐富的可視化工具,其中多個(gè)變量(三個(gè)或更多)在二維平面上進(jìn)行比較,文中給出了完整的代碼示例,需要的朋友可以參考下2024-01-01ECharts坐標(biāo)軸刻度數(shù)值處理方法例子
這篇文章主要給大家介紹了關(guān)于ECharts坐標(biāo)軸刻度數(shù)值處理的相關(guān)資料,文章介紹了一個(gè)用于圖表Y軸數(shù)值簡(jiǎn)寫的函數(shù),它可以將大數(shù)值轉(zhuǎn)換為K、M、B等簡(jiǎn)寫形式,從而使圖表更加美觀和易讀,需要的朋友可以參考下2024-11-11兼容IE,firefox的獲取節(jié)點(diǎn)的文本值的javascript代碼
javascript獲取節(jié)點(diǎn)的文本值,已經(jīng)考慮了兼容性。大家可以放心使用。注意了這里的兼容沒(méi)有使用innerText,如果要使用兼容innerText,請(qǐng)參考腳本之家以前發(fā)布的文章。2009-12-12JavaScript運(yùn)動(dòng)框架 多物體任意值運(yùn)動(dòng)(三)
這篇文章主要為大家詳細(xì)介紹了JavaScript運(yùn)動(dòng)框架的第三部分,多物體任意值運(yùn)動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05QTreeWidget中MainWindow窗體中布局器不起作用詳解
本文主要介紹了QTreeWidget中MainWindow窗體中布局器不起作用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04JavaScript事件監(jiān)聽(tīng)器詳細(xì)介紹
這篇文章主要介紹了JavaScript事件監(jiān)聽(tīng)器詳細(xì)介紹,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-09-09利用 JavaScript 實(shí)現(xiàn)并發(fā)控制的示例代碼
這篇文章主要介紹了利用 JavaScript 實(shí)現(xiàn)并發(fā)控制的示例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常想詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12