uniApp封装全局弹窗供消息推送使用

场景:

当对接websocket时,或者mtqq推送也好,需要获取到最新的信息,并且在任何页面弹出一个组件进行后续操作

第一步:

在 components 文件夹中新建一个组件 webview.vue


 

 

第二步: 

注册一个全局函数,在 utils文件夹中新建一个 invite.js 文件, 使用 Vue.prototype,首先创建一个js文件来存放你的全局方法,之后在main.js中引入挂载

以下代码中几个关键点:

1、install,参数可以拿到Vue函数,等价于 main.js 中 import 进来的 Vue

2、Vue.extend(Invite),这里可以看到 Invite 是我导入的组件实例对象,该方法传入组件实例对象可以返回给你该组件的实例构造器,方便我们后续多次构建并操作该组件

3、instance._props._specia = params,这里只是向新构建的组件内传递一个props参数

4、instance.vm = instance.$mount(),挂载模板,生成真实dom,作用和$el一致

5、invite-box是组件最外层盒子的类名

6、setTimeout,因为要添加到最后,需要异步添加

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() 即可关闭组件

需要传参的话 直接在 this.$openInvite()中传参

例如: this.$openInvite(”你好“)

在mtqq中使用:在接受消息函数中调用 this.$openInvite() 即可

参考:

(3条消息) 封装一个uniapp的全局弹窗组件,vue中也可以使用,在任何页面都可以弹出_jsmeng626的博客-CSDN博客_uniapp 全局弹窗

你可能感兴趣的:(uni-app,websocket,vue,前端)