电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:192日期:2022-06-01 14:22:16
目錄
  • 效果圖:
  • 場景:
  • 思路:
  • 第一步:
  • 第二步:
  • 第三部:使用
  • 總結

效果圖:

場景:

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

思路:

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

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

第一步:

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

以下代碼中幾個關鍵點:

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.jsimport invite from "./utils/invite"http:// 安裝插件Vue.use(invite)

第三部:使用

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

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

總結

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

標簽: JavaScript
主站蜘蛛池模板: uv固化机-丝印uv机-工业烤箱-五金蚀刻机-分拣输送机 - 保定市丰辉机械设备制造有限公司 | 不锈钢管件(不锈钢弯头,不锈钢三通,不锈钢大小头),不锈钢法兰「厂家」-浙江志通管阀 | 昆山PCB加工_SMT贴片_PCB抄板_线路板焊接加工-昆山腾宸电子科技有限公司 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 专注氟塑料泵_衬氟泵_磁力泵_卧龙泵阀_化工泵专业品牌 - 梭川泵阀 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 无机纤维喷涂棉-喷涂棉施工工程-山东华泉建筑工程有限公司▲ | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 电主轴,车床电磨头,变频制动电机-博山鸿达特种电机 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 安徽合肥格力空调专卖店_格力中央空调_格力空调总经销公司代理-皖格制冷设备 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 | 电动百叶窗,开窗器,电动遮阳百叶,电动开窗机生产厂家-徐州鑫友工控科技发展有限公司 | 合肥弱电工程_安徽安防工程_智能化工程公司-合肥雷润 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 上海办公室装修公司_办公室设计_直营办公装修-羚志悦装 | 南京办公用品网-办公文具用品批发-打印机耗材采购 | 北京中航时代-耐电压击穿试验仪厂家-电压击穿试验机 | 两头忙,井下装载机,伸缩臂装载机,30装载机/铲车,50装载机/铲车厂家_价格-莱州巨浪机械有限公司 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 光栅尺_Magnescale探规_磁栅尺_笔式位移传感器_苏州德美达 | 滁州高低温冲击试验箱厂家_安徽高低温试验箱价格|安徽希尔伯特 | 物联网卡_物联网卡购买平台_移动物联网卡办理_移动联通电信流量卡通信模组采购平台? | 超细粉碎机|超微气流磨|气流分级机|粉体改性设备|超微粉碎设备-山东埃尔派粉碎机厂家 | 假肢-假肢价格-假肢厂家-河南假肢-郑州市力康假肢矫形器有限公司 | 莱州网络公司|莱州网站建设|莱州网站优化|莱州阿里巴巴-莱州唯佳网络科技有限公司 | 硫化罐-电加热蒸汽硫化罐生产厂家-山东鑫泰鑫智能装备有限公司 | 波纹补偿器_不锈钢波纹补偿器_巩义市润达管道设备制造有限公司 | 钢结构厂房造价_钢结构厂房预算_轻钢结构厂房_山东三维钢结构公司 | 车牌识别道闸_停车场收费系统_人脸识别考勤机_速通门闸机_充电桩厂家_中全清茂官网 | 干法制粒机_智能干法制粒机_张家港市开创机械制造有限公司 | 升降炉_真空气氛炉_管式电阻炉厂家-山东中辰电炉有限公司 | 珠海冷却塔降噪维修_冷却塔改造报价_凉水塔风机维修厂家- 广东康明节能空调有限公司 | 长沙网站建设制作「网站优化推广」-网页设计公司-速马科技官网 | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 牛皮纸|牛卡纸|进口牛皮纸|食品级牛皮纸|牛皮纸厂家-伽立实业 | 骨密度检测仪_骨密度分析仪_骨密度仪_动脉硬化检测仪专业生产厂家【品源医疗】 | 在线钠离子分析仪-硅酸根离子浓度测定仪-油液水分测定仪价格-北京时代新维测控设备有限公司 | 机床导轨_导轨板_滚轮导轨-上海旻佑精密机械有限公司 | 智慧食堂_食堂管理系统_食堂订餐_食堂消费系统—客易捷 | 泥沙分离_泥沙分离设备_泥砂分离机_洛阳隆中重工机械有限公司 |