Vue 实现一个命令式弹窗组件功能


Posted in Javascript onSeptember 25, 2019

前言

在日常工作中弹窗组件是很常用的组件,但用得多还是别人的,空闲时间就自己来简单实现一个弹窗组件

涉及知识点:extend、$mount、$el

使用方式:

this.$Confirm({
 title:'自定义标题'
}).then(res=>{
  console.log(res)
})

目录结构

Vue 实现一个命令式弹窗组件功能

index.vue:组件布局、样式、交互逻辑

index.js:挂载组件、暴露方法

知识点

在此之前,了解下涉及的知识点

1. extend

Vue 实现一个命令式弹窗组件功能

 使用这个api,可以将引入的vue组件变成vue构造函数,实例化后方便进行扩展

2. $mount

Vue 实现一个命令式弹窗组件功能

我们希望弹窗组件是在使用时才显示出来,那么就需要动态的向body中添加元素。使用$mount方法可以手动挂载一个vue实例,和 extend 刚好搭配使用,这个也是弹窗组件命令式的关键。

3. $el

Vue 实现一个命令式弹窗组件功能

 既然要添加dom元素,通过实例的$el属性,正好可以取到dom元素,之后就是使用原生方法进行添加节点啦~

代码实现

index.vue

<template>
  <div class="wrap">
    <div class="main">
      <div class="content">
        {{title}}
      </div>
      <div class="btn-grounp">
        <div class="btn cancel" @click="cancel">{{cancelText}}</div>
        <div class="btn confirm" @click="confirm">{{confirmText}}</div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  name:'',
  data () {
    return {
      title:'这是一个弹窗',
      confirmText:'确定',
      cancelText:'取消'
    };
  },
  methods: {
    show(cb){
      typeof cb === 'function' && cb.call(this,this)
      return new Promise(resolve=>{
        this.resolve = resolve
      })
    },
    confirm(){
      this.resolve('confirm')
      this.hide()
    },
    cancel(){
      this.resolve('cancel')
      this.hide()
    },
    hide(){
      document.body.removeChild(this.$el)
      this.$destroy()
    }
  },
}

</script>
<style scoped>
.wrap{
  position: fixed;
  top: 0;
  bottom:0;
  left:0;
  right:0;
  display:flex;
  justify-content: center;
  align-items: center;
  background: rgba(0,0,0,.3);
}
.main{
  width: 30%;
  padding: 10px;
  background: #fff;
  box-shadow: 0 0 10px 1px #ddd;
  border-radius: 5px;
}
.content{
  color:#424242;
  font-size: 20px;
}
.btn-grounp{
  margin-top: 15px;
  display:flex;
  justify-content: flex-end;
}
.btn{
  margin-left: 15px;
  padding: 5px 20px;
  border-radius: 5px;
  font-size: 16px;
  color:#fff;
}
.confirm{
  background: lightblue;
}
.cancel{
  background: lightcoral;
}
</style>

index.js

import Vue from 'vue'
import comfirm from './index.vue'
let newInstance = null
//将vue组件变为构造函数
let ConfirmConstructor = Vue.extend(comfirm)
let init = (options)=>{
  //实例化组件
  newInstance = new ConfirmConstructor()
  //合并配置选项
  Object.assign(newInstance,options)
  //加载dom
  document.body.appendChild(newInstance.$el)
}
let caller = (options)=>{
  //options 为调用组件方法时传入的配置选项
  if(!newInstance){
    init(options)
  }
  return newInstance.show(vm =>{newInstance = null})
}
export default {
  install(vue){
    vue.prototype.$Confirm = caller
  }
}

main.js

上面我对外暴露的对象中含有install方法,这里可以使用Vue.use注册组件(使用Vue.use后,会查找install方法进行调用),将组件调用方法挂载到Vue原型上。

import Confirm from './components/confirm'
Vue.use(Confirm)

写在最后

这个弹窗组件比较简陋,还有很多地方可以完善,等有时间再搞了~

总结

以上所述是小编给大家介绍的Vue 实现一个命令式弹窗组件功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
javascript 避免闭包引发的问题
Mar 17 Javascript
javascript表单验证 - Parsley.js使用和配置
Jan 25 Javascript
jQuery实现复选框成对选择及对应取消的方法
Mar 03 Javascript
详解AngularJS中自定义指令的使用
Jun 17 Javascript
值得分享的Bootstrap Ace模板实现菜单和Tab页效果
Dec 30 Javascript
关于JavaScript作用域你想知道的一切
Feb 04 Javascript
详解AngularJS过滤器的使用
Mar 11 Javascript
jQuery表单验证之密码确认
May 22 jQuery
详解基于Bootstrap+angular的一个豆瓣电影app
Jun 26 Javascript
vue-cli3 项目从搭建优化到docker部署的方法
Jan 28 Javascript
小程序测试后台服务的方法(ngrok)
Mar 08 Javascript
vue 组件基础知识总结
Jan 26 Vue.js
layui prompt 设置允许空白提交的方法
Sep 24 #Javascript
微信小程序制作扭蛋机代码实例
Sep 24 #Javascript
layer.prompt输入层的例子
Sep 24 #Javascript
layer插件实现在弹出层中弹出一警告提示并关闭弹出层的方法
Sep 24 #Javascript
解决layer.prompt无效的问题
Sep 24 #Javascript
layer.prompt使文本框为空的情况下也能点击确定的方法
Sep 24 #Javascript
layui-table获得当前行的上/下一行数据的例子
Sep 24 #Javascript
You might like
php dirname(__FILE__) 获取当前文件的绝对路径
2011/06/28 PHP
PHP中使用mktime获取时间戳的一个黑色幽默分析
2012/05/31 PHP
php实现单链表的实例代码
2013/03/22 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(二)
2014/06/23 PHP
php冒泡排序与快速排序实例详解
2015/12/07 PHP
在Mac OS上编译安装Nginx+PHP+MariaDB开发环境的教程
2016/02/23 PHP
laravel5创建service provider和facade的方法详解
2016/07/26 PHP
php自动加载代码实例详解
2021/02/26 PHP
Json对象替换字符串占位符实现代码
2010/11/17 Javascript
js 调用父窗口的具体实现代码
2013/07/15 Javascript
获取非最后一列td值并将title设为该值的方法
2013/10/30 Javascript
Bootstrap 组件之按钮(二)
2016/05/11 Javascript
Laravel中常见的错误与解决方法小结
2016/08/30 Javascript
js闭包学习心得总结
2018/04/17 Javascript
React native ListView 增加顶部下拉刷新和底下点击刷新示例
2018/04/27 Javascript
JavaScript动态创建二维数组的方法示例
2019/02/01 Javascript
javascript实现自由编辑图片代码详解
2019/06/21 Javascript
JS根据Unix时间戳显示发布时间是多久前【项目实测】
2019/07/10 Javascript
js实现列表向上无限滚动
2020/01/13 Javascript
Python的净值数据接口调用示例分享
2016/03/15 Python
Python中 传递值 和 传递引用 的区别解析
2018/02/22 Python
python数字图像处理之骨架提取与分水岭算法
2018/04/27 Python
基于Python中求和函数sum的用法详解
2018/06/28 Python
python实现扫描ip地址的小程序
2019/04/16 Python
Python autoescape标签用法解析
2020/01/17 Python
Django单元测试中Fixtures用法详解
2020/02/25 Python
不同浏览器对CSS3和HTML5的支持状况
2009/10/31 HTML / CSS
HTML5 Canvas的事件处理介绍
2015/04/24 HTML / CSS
大学学习生活感言
2014/01/18 职场文书
优秀班干部事迹材料
2014/01/26 职场文书
创建无烟单位实施方案
2014/03/29 职场文书
酒会邀请函
2015/01/31 职场文书
幼儿园校车安全责任书
2015/05/08 职场文书
新年祝酒词大全
2015/08/11 职场文书
nginx部署多前端项目的几种方法
2021/05/25 Servers
为什么MySQL分页用limit会越来越慢
2021/07/25 MySQL