文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么封装一个vue中也可使用的uniapp全局弹窗组件

2023-07-05 06:00

关注

这篇文章主要介绍了怎么封装一个vue中也可使用的uniapp全局弹窗组件的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么封装一个vue中也可使用的uniapp全局弹窗组件文章都会有所收获,下面我们一起来看看吧。

场景:

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

思路:

先封装好要弹出的公共组件

向vue原型上挂载全局方法,拿到组件真实dom,从而对组件进行显隐操作

第一步:

创建一个公共组件,以下是组件全部的结构及样式,你需要把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,首先创建一个js文件来存放你的全局方法,之后在main.js中引入挂载

以下代码中几个关键点:

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

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

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

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

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

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.jsimport invite from './utils/invite'// 安装插件Vue.use(invite)

第三部:使用

在你任何组件内调用 this.$openInvite() 即可弹出组件,调用 this.$closeInvite()即可关闭组件

关于“怎么封装一个vue中也可使用的uniapp全局弹窗组件”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“怎么封装一个vue中也可使用的uniapp全局弹窗组件”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯