Vue全局弹框组件封装

前言

最近在项目中自己封装的一个记录一下

效果图

在这里插入图片描述

弹框组件

popup/PopupDialog.vue
		<template>
		  <div v-show="show" class="frame" style="z-index: 2001">
		    <div class="adduse">
		      <div class="frameHeader">{{ title }}</div>
		      <div class="elvesIcon" @click="closeDialog" />
		      <div class="frameBody">
		        <div class="content">
		          <img class="first img" src="@/assets/image/first.svg" alt="第一步">
		          <div class="box">
		            <span class="noDescription">{{ firstContent }}</span>
		            <span
		              class="url"
		              @click="goto('1')"
		            >xxxx</span>
		          </div>
		        </div>
		        <div class="content">
		          <img
		            class="second img"
		            src="@/assets/image/second.svg"
		            alt="第二步"
		          >
		          <div class="box s2">
		            <span class="noAccess">{{ secondContent }}</span>
		            <span
		              class="url"
		              @click="goto"
		            >http://usp.oppoer.me/#/jurisdiction</span>
		          </div>
		        </div>
		      </div>
		      <div class="frameFooter">
		        <span class="cancel" @click="closeDialog">{{ define }}</span>
		      </div>
		    </div>
		  </div>
		</template>

	<script>
	export default {
	  data () {
	    return {
	      show: false,
	      title: '权限申请',
	      firstContent: 'GRS权限说明:',
	      secondContent: '权限申请:',
	      define: '确定'
	    }
	  },
	  created () {
	    this.languageSwitch()
	  },
	  methods: {
	    languageSwitch () {
	      const lang = localStorage.getItem('locale')
	      this.title = lang === 'en' ? 'Access Request' : '权限申请'
	      this.firstContent =
	        lang === 'en' ? 'GRS Permission description:' : 'GRS权限说明:'
	      this.secondContent = lang === 'en' ? 'Access Request:' : '权限申请:'
	      this.define = lang === 'en' ? 'determine' : '确定'
	    },
	    goto (val) {
	      if (val === '1') {
	        window.open('xxxxx')
	      } else {
	        window.open('xxxx')
	      }
	    },
	    closeDialog () {
	      this.show = false
	    }
	  }
	}
	</script>

<style lang="scss" scoped>
.frame {
	 position: fixed;
	 top: 0;
	 right: 0;
	 bottom: 0;
	 left: 0;
	 overflow: auto;
	 margin: 0;
	 background: rgba(0, 0, 0, 0.5);
	 .adduse {
	   background: #ffffff;
	   box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
	   border-radius: 5px;
	   position: relative;
	   margin: 0 auto 50px;
	   margin-top: 15vh;
	   padding: 0;
	   width: 728px;
	   height: 300px;
	   min-width: 800px;
	   .frameHeader {
	     padding: 20px 20px 10px;
	     border-bottom: 1px solid rgba(0, 0, 0, 0.09);
	   }
   .elvesIcon {
	      background-image: url();
     background-size: 100% 100%;
     width: 16px;
     height: 16px;
     position: absolute;
     right: 20px;
     top: 20px;
     cursor: pointer;
     &:hover {
       background-image: url();
     }
   }
   .frameBody {
     padding: 40px 10px 10px;
     .content {
       padding-left: 50px;
       padding-bottom: 30px;
       &:last-child {
         padding-bottom: 0;
       }
       .img {
         width: 40px;
         height: 40px;
         vertical-align: middle;
       }
       .box {
         display: inline-block;
         vertical-align: middle;
         padding-left: 10px;
         &.s2 {
           padding-left: 45px;
         }
         .url {
           color: #3081f2;
           cursor: pointer;
         }
       }
     }
   }
   .frameFooter {
     background: #fbfdfe;
     border-radius: 3px;
     position: absolute;
     bottom: 0;
     width: 100%;
     height: 53px;
     display: flex;
     justify-content: center;
     align-items: center;
     border-top: 1px solid rgba(0, 0, 0, 0.09);
     .cancel {
       display: inline-block;
       cursor: pointer;
       border: 1px solid #3081f2;
       color: #fff;
       width: 66px;
       height: 32px;
       background: #3081f2;
       font-size: 14px;
       line-height: 32px;
       box-sizing: border-box;
       text-align: center;
       border-radius: 5px;
       opacity: 0.8;
       &:hover {
         color: #fff;
         border-color: #3081f2;
         background-color: #3081f2;
         opacity: 1;
       }
     }
   }
 }
}
</style>

popup-dialog.js

	utils/popup-dialog.js
		import Vue from 'vue'
		import Popup from '@/components/popup/PopupDialog'
		
		const PopupBox = Vue.extend(Popup)
		
		Popup.install = function (data) {
		  const instance = new PopupBox({
		    data
		  }).$mount()
		
		  document.body.appendChild(instance.$el)
		
		  Vue.nextTick(() => {
		    // show 和弹窗组件里的show对应,用于控制显隐
		    instance.show = true
		  })
		}
		
		export default Popup

main.js引入popup-dialog.js

import Popup from '@/utils/popup-dialog'
// 全局可使用this.$popup调用
Vue.prototype.$popup = Popup.install

需要使用的地方使用方法

this.$popup()

这个地方可以配置一些自定义的方法和要传递的数据,根据你的的需求来定,我这里只是展示出来就可以,配置的话是在弹框组件里进行配置,使用的时候通过this.$popup({…})

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值