亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

封裝一個(gè)vue中也可使用的uniapp的全局彈窗組件(任何頁(yè)面都可以彈出)

瀏覽:103日期:2022-06-01 14:22:16
目錄
  • 效果圖:
  • 場(chǎng)景:
  • 思路:
  • 第一步:
  • 第二步:
  • 第三部:使用
  • 總結(jié)

效果圖:

場(chǎng)景:

當(dāng)你對(duì)接websocket時(shí),或者輪詢(xún)也好,你需要獲取到最新的信息,并且在任何頁(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>    <view>      <image src="/static/invite-logo.png"></image>      <image src="/static/close.png" v-on:click="$closeInvite"></image>      <view>邀請(qǐng)函</view>      <view>您好!您的朋友xxx邀請(qǐng)您對(duì)<text>“為什么小朋友到了一定年齡需要打疫苗?”</text>進(jìn)行專(zhuān)家答疑,您是否接受?</view>      <view><view>邀請(qǐng)專(zhuān)家</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是組件最外層盒子的類(lèi)名

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.jsimport invite from "./utils/invite"http:// 安裝插件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)文章希望大家以后多多支持!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 三级毛片视频 | 国产成人精品亚洲2020 | 欧美中文字幕在线视频 | 麻豆网站在线免费观看 | 亚洲欧美在线精品一区二区 | 麻豆免费永久网址入口网址 | 国产欧美日韩精品综合 | 麻豆国产精品免费视频 | 色琪琪综合网站 | 丁香六月婷婷精品免费观看 | 国产高清免费视频 | 婷婷综合影院 | 日本黄色片一级片 | 久久久久99 | 国产精品二区三区 | 婷婷久久综合网 | 高清精品一区二区三区一区 | 国产91精选在线观看麻豆 | 草草国产 | 一级欧美一级日韩毛片99 | 中文字幕亚洲无线码高清 | 丝袜捆绑调教视频免费区 | 69日本人xxxxx成熟98 | 99精品视频在线观看免费播放 | 污免费网站| 国产亚洲精品综合在线网址 | 欧美三级欧美成人高清www | 国产又黄又爽又色视频免费观看 | 日本一级毛片在线看 | 亚洲欧美久久久久久久久久爽网站 | 亚洲日本国产 | 国产欧美日韩一区二区三区 | 精品视频手机在线观看免费 | 在线观看中文字幕国产 | 日韩女同一区二区三区 | 国产一区免费在线观看 | 亚洲性色综合图区图片 | 日韩免费毛片视频 | 一级免费视频 | 日韩久草 | 国产精品jizz视频 |