搜索

查看: 3075|回复: 11

[JavaScript] 封装一个vue中也可使用的uniapp的全局弹窗组件(任何页面都可以弹出)

[复制链接]
发表于 2023-5-4 11:49:16 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:49:16 3075 11 看全部
目录
  • 效果图:
  • 场景:
  • 思路:
  • 第一步:
  • 第二步:
  • 第三部:使用
  • 总结
    效果图:

    2023022309280013.png

    2023022309280013.png


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

    思路:
    1、先封装好要弹出的公共组件
    2、向vue原型上挂载全局方法,拿到组件真实dom,从而对组件进行显隐操作

    第一步:
    创建一个公共组件,以下是组件全部的结构及样式,你需要把html中的两个image标签的路径换掉或者直接注释掉也行,html 和 css就不做解释了

    invite.vue

      
       
          
          
          邀请函
          您好!您的朋友xxx邀请您对“为什么小朋友到了一定年龄需要打疫苗?”进行专家答疑,您是否接受?
          
            邀请专家
          
             
      


    .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;
          }
        }
      }
    }

    第二步:
    注册一个全局函数,使用 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,因为要添加到最后,需要异步添加

    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全局弹窗组件封装内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
  • 知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 00:25:00 | 显示全部楼层
    123456848 2023-6-29 00:25:00 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 17:42:57 | 显示全部楼层
    123456833 2023-6-29 17:42:57 看全部
    这东西我收了!谢谢楼主!知鸟论坛真好!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 17:52:45 | 显示全部楼层
    永远爱你冰塘 2023-6-29 17:52:45 看全部
    这东西我收了!谢谢楼主!知鸟论坛真好!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 19:19:08 | 显示全部楼层
    六翼天使494 2023-6-29 19:19:08 看全部
    这东西我收了!谢谢楼主!知鸟论坛真好!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 19:21:00 | 显示全部楼层
    xinting_6ym 2023-6-29 19:21:00 看全部
    楼主太厉害了!楼主,I*老*虎*U!我觉得知鸟论坛真是个好地方!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-29 19:49:08 | 显示全部楼层
    伊索谗言 2023-6-29 19:49:08 看全部
    感谢楼主的无私分享!要想知鸟论坛好 就靠你我他
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-30 11:12:25 | 显示全部楼层
    井底燕雀傥 2023-6-30 11:12:25 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-6-30 16:18:48 | 显示全部楼层
    123456809 2023-6-30 16:18:48 看全部
    楼主,大恩不言谢了!知鸟论坛是最棒的!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    发表于 2023-7-1 02:43:58 | 显示全部楼层
    丁侦球 2023-7-1 02:43:58 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    知鸟论坛永久地址发布页:www.zn60.me
    回复

    使用道具 举报

    • 您可能感兴趣
    点击右侧快捷回复 【请勿灌水】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| SiteMap| 小黑屋| 赞兔论坛
    联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表