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 相关文章推荐
js验证输入是否为手机号码或电话号码示例
Dec 30 Javascript
Extjs Label的 fieldLabel和html属性值对齐的方法
Jun 15 Javascript
完美兼容各大浏览器获取HTTP_REFERER方法总结
Jun 24 Javascript
jQuery/CSS3图片特效插件整理推荐
Dec 07 Javascript
javascript实现限制上传文件大小
Feb 06 Javascript
jquery可定制的在线UEditor编辑器
Nov 17 Javascript
浅谈react-router HashRouter和BrowserRouter的使用
Dec 29 Javascript
CentOS环境中MySQL修改root密码方法
Jan 07 Javascript
详解vue项目中实现图片裁剪功能
Jun 07 Javascript
ES6之Proxy的get方法详解
Oct 11 Javascript
Vue程序化的事件监听器(实例方案详解)
Jan 07 Javascript
JavaScript 事件代理需要注意的地方
Sep 08 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
深入了解PHP类Class的概念
2012/06/14 PHP
使用php显示搜索引擎来的关键词
2014/02/13 PHP
PHP调用VC编写的COM组件实例
2014/03/29 PHP
PHP合并discuz用户脚本的方法
2015/08/04 PHP
PHP图像识别技术原理与实现
2016/10/27 PHP
Laravel5中Cookie的使用详解
2017/05/03 PHP
PHP实现的链式队列结构示例
2017/09/15 PHP
用AJAX返回HTML片段中的JavaScript脚本
2010/01/04 Javascript
Three.js源码阅读笔记(物体是如何组织的)
2012/12/27 Javascript
js 立即调用的函数表达式如何写
2014/01/12 Javascript
javascript中match函数的用法小结
2014/02/08 Javascript
jQuery实现有动画淡出效果的二级折叠菜单代码
2015/10/17 Javascript
jQuery实现滚动条滚动到子元素位置(方便定位)
2017/01/08 Javascript
jQuery animate()实现背景色渐变效果的处理方法【使用jQuery.color.js插件】
2017/03/15 Javascript
JS实现前端页面的搜索功能
2018/06/12 Javascript
小程序实现录音功能
2020/09/22 Javascript
原生JS生成指定位数的验证码
2020/10/28 Javascript
Vue+Bootstrap实现简易学生管理系统
2021/02/09 Vue.js
Django教程笔记之中间件middleware详解
2018/08/01 Python
一看就懂得Python的math模块
2018/10/21 Python
安装docker-compose的两种最简方法
2019/07/30 Python
python机器学习包mlxtend的安装和配置详解
2019/08/21 Python
python返回数组的索引实例
2019/11/28 Python
python3 deque 双向队列创建与使用方法分析
2020/03/24 Python
python接入支付宝的实例操作
2020/07/20 Python
世界各地的当地人的食物体验:Eatwith
2019/07/26 全球购物
英国泽西岛植物:Jersey Plants Direct
2019/08/07 全球购物
Jack Rogers官网:美国经典的女性鞋靴品牌
2019/09/04 全球购物
学生打架检讨书大全
2014/01/23 职场文书
职业生涯规划书范文
2014/03/10 职场文书
团队经理竞聘书
2014/03/31 职场文书
毕业生找工作自荐书
2014/06/30 职场文书
2014年大学生预备党员思想汇报1000字
2014/09/13 职场文书
导游词之江南园林狮子林
2019/09/16 职场文书
Django分页器的用法你都了解吗
2021/05/26 Python
Python图片验证码降噪和8邻域降噪
2021/08/30 Python