欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2023年02月23日 09:33:12   作者:jsmeng626  
在寫uniapp小程序的時候,彈窗提醒經常會用到,雖然彈窗的組件很多,但是通常別人封裝好的彈窗組件自定義度不高,很難匹配自己的ui需求,這篇文章主要給大家介紹了封裝一個vue中也可使用的uniapp的全局彈窗組件的相關資料,這個組件在任何頁面都可以彈出,需要的朋友可以參考下

效果圖:

場景:

當你對接websocket時,或者輪詢也好,你需要獲取到最新的信息,并且在任何頁面彈出一個組件進行后續(xù)操作

思路:

1、先封裝好要彈出的公共組件

2、向vue原型上掛載全局方法,拿到組件真實dom,從而對組件進行顯隱操作

第一步:

創(chuàng)建一個公共組件,以下是組件全部的結構及樣式,你需要把html中的兩個image標簽的路徑換掉或者直接注釋掉也行,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">邀請函</view>
      <view class="content">您好!您的朋友xxx邀請您對<text>“為什么小朋友到了一定年齡需要打疫苗?”</text>進行專家答疑,您是否接受?</view>
      <view class="btn-group">
        <view class="invite-specia">邀請專家</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>

第二步:

注冊一個全局函數,使用 Vue.prototype,首先創(chuàng)建一個js文件來存放你的全局方法,之后在main.js中引入掛載

以下代碼中幾個關鍵點:

1、install,參數可以拿到Vue函數,等價于 main.js 中 import 進來的 Vue

2、Vue.extend(Invite),這里可以看到 Invite 是我導入的組件實例對象,該方法傳入組件實例對象可以返回給你該組件的實例構造器,方便我們后續(xù)多次構建并操作該組件

3、instance._props._specia = params,這里只是向新構建的組件內傳遞一個props參數

4、instance.vm = instance.$mount(),掛載模板,生成真實dom,作用和$el一致

5、invite-box是組件最外層盒子的類名

6、setTimeout,因為要添加到最后,需要異步添加

 invite.js

import Invite from '../components/invite.vue'
 
export default {
  install(Vue) {
    const Profile = Vue.extend(Invite)
    
    // 彈出邀請
    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
    }
 
    // 關閉邀請
    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

// 導入invite.js
import invite from './utils/invite'
// 安裝插件
Vue.use(invite)

第三部:使用

在你任何組件內調用 this.$openInvite() 即可彈出組件,調用 this.$closeInvite()即可關閉組件

以上就是整個過程,是不是很好用呢

總結

到此這篇關于封裝一個vue中也可使用的uniapp的全局彈窗組件的文章就介紹到這了,更多相關uniapp全局彈窗組件封裝內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 瀏覽器圖片選擇預覽、旋轉、批量上傳的JS代碼實現

    瀏覽器圖片選擇預覽、旋轉、批量上傳的JS代碼實現

    這篇文章主要介紹了瀏覽器圖片選擇預覽、旋轉、批量上傳的JS代碼實現,有需要的朋友可以參考一下
    2013-12-12
  • echarts實現雷達圖的詳細步驟

    echarts實現雷達圖的詳細步驟

    這篇文章主要給大家介紹了關于echarts實現雷達圖的詳細步驟,雷達圖(Radar?Chart)是一種信息豐富的可視化工具,其中多個變量(三個或更多)在二維平面上進行比較,文中給出了完整的代碼示例,需要的朋友可以參考下
    2024-01-01
  • js數據類型以及其判斷方法實例

    js數據類型以及其判斷方法實例

    這篇文章主要給大家介紹了關于js數據類型以及其判斷方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • ECharts坐標軸刻度數值處理方法例子

    ECharts坐標軸刻度數值處理方法例子

    這篇文章主要給大家介紹了關于ECharts坐標軸刻度數值處理的相關資料,文章介紹了一個用于圖表Y軸數值簡寫的函數,它可以將大數值轉換為K、M、B等簡寫形式,從而使圖表更加美觀和易讀,需要的朋友可以參考下
    2024-11-11
  • 兼容IE,firefox的獲取節(jié)點的文本值的javascript代碼

    兼容IE,firefox的獲取節(jié)點的文本值的javascript代碼

    javascript獲取節(jié)點的文本值,已經考慮了兼容性。大家可以放心使用。注意了這里的兼容沒有使用innerText,如果要使用兼容innerText,請參考腳本之家以前發(fā)布的文章。
    2009-12-12
  • JavaScript運動框架 多物體任意值運動(三)

    JavaScript運動框架 多物體任意值運動(三)

    這篇文章主要為大家詳細介紹了JavaScript運動框架的第三部分,多物體任意值運動,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • QTreeWidget中MainWindow窗體中布局器不起作用詳解

    QTreeWidget中MainWindow窗體中布局器不起作用詳解

    本文主要介紹了QTreeWidget中MainWindow窗體中布局器不起作用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • Javascript中的對象和原型(二)

    Javascript中的對象和原型(二)

    這篇文章給大家介紹了js中的對象和原型,從工廠模式,構造函數方面展開話題,介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • JavaScript事件監(jiān)聽器詳細介紹

    JavaScript事件監(jiān)聽器詳細介紹

    這篇文章主要介紹了JavaScript事件監(jiān)聽器詳細介紹,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-09-09
  • 利用 JavaScript 實現并發(fā)控制的示例代碼

    利用 JavaScript 實現并發(fā)控制的示例代碼

    這篇文章主要介紹了利用 JavaScript 實現并發(fā)控制的示例代碼,本文通過實例代碼給大家介紹的非常想詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12

最新評論