vue 全局弹窗内容自定义

  • 最近项目中要用到二次确认组件,因为考虑到多出使用多次回调所以普通的公共组件满足不了。
  • 我需要的是this.massage();这种,所以就自己封装了一个,全局都可以使用

src/components 下创建公共组件 visible.vue

visible.vue

<!-- 二次确认组件 -->
<template>
	<section class='visible'>
		<el-dialog :visible.sync="visible" top="35vh" :destroy-on-close="true" width="752px">

			<div class="title">

				<h1>{{title}}</h1>

				<i @click="visible = false" class="iconfont iconguanbiicon-"></i>

			</div>

			<div class="fieos">

				<div class="pont_item">

					<img width="25px" height="25px" class="mr20" src="@/assets/image/tite@2x.png" alt="">

					<p>{{text}}</p>

				</div>

				<div class="pont_item flex_justify_end">

					<el-button @click="visible=false">取消</el-button>

					<el-button @click="onSub" type="primary">确定</el-button>

				</div>

			</div>

		</el-dialog>
	</section>
</template>
   
<script>
export default {

	data() {
		return {
            visible:true
		};
	},

	methods: {
        onSub(){
            this.determine(true)
            
            setTimeout(()=>{
                this.visible = false;
            },200)
        }
	},

};
</script>

assets/js创建 plug.js

import vue from 'vue'
import toastComponent from '@/components/visible.vue'

// 返回扩展实例构造器
const ToastConstructor = vue.extend(toastComponent)

// 三个参数 determine是回调函数,点击确认回调
function showVisible(title = '提示', text = '文本', determine = () => {}) {
    const toastDom = new ToastConstructor({
        el: document.createElement('div'),
        data() {
            return {
                title,
                text,
                determine,
            }
        }
    })
    document.body.appendChild(toastDom.$el)
}

// 注册为全局组件
function registryToast() {
    vue.prototype.$visible = showVisible
}

export default registryToast

main.js 引入plug.js

import visible from './assets/js/plug';
Vue.use(visible)

在组件中使用

this.$visible('删除科室', '是否删除此科室?', res => {
	console.log(res);// 点击了确认
 })

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值