Vue自定义全局弹窗组件操作


Posted in Javascript onAugust 11, 2020

写在前面

页面中会有很多时候需要弹窗提示,我们可以写一个弹窗组件,但是如果每个页面都引入这个组件,太麻烦了,所以我们将它变成全局组件,需要用的时候直接通过JS调用即可,不需要在每个页面引入了

效果图

Vue自定义全局弹窗组件操作

弹窗组件

新建一个弹窗的组件——popup.vue

<template>
 <transition name='fade'>
  <!-- 蒙版 -->
  <div class="mask" v-if="show" @touchmove.prevent>
   <div class="window">
    <img class="shadow" :src="imgUrl" alt="">
    <h1>{{title}}</h1>
    <p>{{content}}</p>
    <button @click="btnClick">{{btnText}}</button>
   </div>
   <img @click="show = false" v-fb class="close" src="../../../pages/signin/dialog/images/关闭.png" alt="">
  </div>
 </transition>
</template>

<script>
export default {
 name: 'app',
 data () {
  return {
   show: false,
   imgUrl: '',
   title: '',
   content: '',
   btnText: '',
   click: ''
  }
 },
 created () {
 },
 methods: {
  btnClick () {
   this.click()
   this.show = false
  }
 }
}
</script>

<style lang="less" scoped>
 @import "../../../assets/css/minx/minx";
 @import "../../../assets/css/pixel/pixel";
 // 渐变过渡
 .fade-enter,
 .fade-leave-active {
  opacity: 0;
 }
 .fade-enter-active,
 .fade-leave-active {
  transition: opacity .35s;
 }
 // 全局弹窗
 .mask {
  .fixed;
  z-index: 10;
  background:rgba(0,0,0,0.65);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
   padding: 75/75rem;
  .window{
   height: 400/75rem;
   width: 100%;
   background: #fff;
   border-radius:8px;
   text-align: center;
   .shadow{
    width: 270/75rem;
    margin-top: -90/75rem;
   }
   h1{
    margin-top: 32/75rem;
    font-size:32/75rem;
    color:#f1300b;
    line-height:32/75rem;
    font-weight: 600;
   }
   p{
    margin-top: 32/75rem;
    font-size:28/75rem;
    color:#222222;
    line-height:40/75rem;
   }
   button{
    margin-top: 34/75rem;
    background:#f95644;
    border-radius:10px;
    width:23/75remx;
    height:64/75rem;
    font-size:28/75rem;
    color:#ffffff;
   }
  }
  .close{
   width:60/75rem;
   height:60/75rem;
   margin-top: 40/75rem;
  }
 }
</style>

popup.js文件

新建一个popup.js文件,写方法

import Vue from 'vue'
import Popup from './popup.vue'
const PopupBox = Vue.extend(Popup)

Popup.install = function (data) {
 let instance = new PopupBox({
  data
 }).$mount()

 document.body.appendChild(instance.$el)

 Vue.nextTick(() => {
  instance.show = true
  // show 和弹窗组件里的show对应,用于控制显隐
 })
}
export default Popup

main.js引入popup.js

// 自定义全局弹窗组件
import Vue from 'vue'
import Popup from './components/dialog/popup'
Vue.prototype.$popup = Popup.install

组件中使用方法

methods: {
 btnClick () {
  this.$popup({
   imgUrl: require('../../../static/images/shadow.png'), // 顶部图片
   title: '我是标题',
   content: '我是内容',
   btnText: '我是按钮',
   click: () => {
    // 点击按钮事件
    this.$router.push('……')
   }
  })
 }
}

方便以后自己使用,大家也可以参考哦,也希望大家多多支持三水点靠木,谢谢~~

Javascript 相关文章推荐
javascript+dom树型菜单类,希望朋友们一起进步
May 03 Javascript
权威JavaScript 中的内存泄露模式
Aug 13 Javascript
JQuery扩展插件Validate 3通过参数设置错误信息
Sep 05 Javascript
javascript单引号和双引号的区别和处理
May 14 Javascript
JavaScript+CSS实现的可折叠二级菜单实例
Feb 29 Javascript
Bootstrap学习笔记之css样式设计(2)
Jun 07 Javascript
vue脚手架中配置Sass的方法
Jan 04 Javascript
微信小程序如何获取用户信息
Jan 26 Javascript
socket io与vue-cli的结合使用的示例代码
Nov 01 Javascript
使用axios请求时,发送formData请求的示例
Oct 29 Javascript
浅谈vue的第一个commit分析
Jun 08 Javascript
工作中常用js功能汇总
Nov 07 Javascript
基于Vue全局组件与局部组件的区别说明
Aug 11 #Javascript
VUE使用 wx-open-launch-app 组件开发微信打开APP功能
Aug 11 #Javascript
vue实现图片按比例缩放问题操作
Aug 11 #Javascript
JavaScript中while循环的基础使用教程
Aug 11 #Javascript
vue-cli3 引入 font-awesome的操作
Aug 11 #Javascript
js实现列表按字母排序
Aug 11 #Javascript
Vue使用轮询定时发送请求代码
Aug 10 #Javascript
You might like
ThinkPHP安装和设置
2015/07/27 PHP
PHP下的浮点运算不准的解决方法
2016/10/27 PHP
Laravel中服务提供者和门面模式的入门介绍
2017/11/06 PHP
PHP切割整数工具类似微信红包金额分配的思路详解
2019/09/18 PHP
IE浏览器PNG图片透明效果代码
2008/09/02 Javascript
javascript 打开页面window.location和window.open的区别
2010/03/17 Javascript
javascript,jquery闭包概念分析
2010/06/19 Javascript
JQuery中DOM加载与事件执行实例分析
2015/06/13 Javascript
JS小数运算出现多为小数问题的解决方法
2016/06/02 Javascript
详解如何使用node.js的开发框架express创建一个web应用
2018/12/20 Javascript
浅谈JavaScript_DOM学习篇_图片切换小案例
2019/03/19 Javascript
Vue+element 解决浏览器自动填充记住的账号密码问题
2019/06/11 Javascript
JavaScript常用内置对象用法分析
2019/07/09 Javascript
layui关闭层级、简单监听的实例
2019/09/06 Javascript
[47:45]Liquid vs OG 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python日期操作学习笔记
2008/10/07 Python
使用优化器来提升Python程序的执行效率的教程
2015/04/02 Python
Python栈类实例分析
2015/06/15 Python
对python:循环定义多个变量的实例详解
2019/01/20 Python
Python 面向对象之封装、继承、多态操作实例分析
2019/11/21 Python
使用python去除图片白色像素的实例
2019/12/12 Python
python super用法及原理详解
2020/01/20 Python
python tkinter之顶层菜单、弹出菜单实例
2020/03/04 Python
利用python+request通过接口实现人员通行记录上传功能
2021/01/13 Python
Html5游戏开发之乒乓Ping Pong游戏示例(二)
2013/01/21 HTML / CSS
HTML5新增加标签和功能概述
2016/09/05 HTML / CSS
优秀中学生事迹材料
2014/01/31 职场文书
群众路线领导干部个人对照检查材料(集锦)
2014/09/23 职场文书
群众路线个人自我剖析材料
2014/10/07 职场文书
收银员岗位职责
2015/02/03 职场文书
法律服务所工作总结
2015/08/10 职场文书
教师正风肃纪心得体会
2016/01/15 职场文书
教育教学工作反思
2016/02/24 职场文书
2019新员工试用期转正申请书3篇
2019/08/13 职场文书
MySQL安装后默认自带数据库的作用详解
2021/04/27 MySQL
MySQL8.0的WITH查询详情
2021/08/30 MySQL