Vue ElementUI this.$confirm async await封装方式
更新时间:2022年09月23日 15:47:22 作者:asdfsdgfsdgfa
这篇文章主要介绍了Vue ElementUI this.$confirm async await封装方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
Vue ElementUI this.$confirm async await封装
this.$confirm官网:
https://element.eleme.cn/#/zh-CN/component/message-box
改造前
async test() { console.log("111111"); this.$confirm("此操作将永久删除该文件, 是否继续?", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning", }) .then(() => { console.log("点击确定"); this.$message({ type: "success", message: "删除成功!", }); }) .catch(() => { console.log("点击取消"); this.$message({ type: "info", message: "已取消删除", }); }); console.log("2222222"); },
async await改造后
async test() { console.log("111111"); let confirmRes = await this.$confirm( "此操作将永久删除该文件, 是否继续?", "提示", { confirmButtonText: "确定", cancelButtonText: "取消", type: "warning", } ).catch(() => {}); if (confirmRes !== "confirm") { console.log("点击取消"); return; } console.log("点击确定"); console.log("2222222"); }
一定要加上.catch(() => {});否则报错
Vue elementUI组件封装思路
核心
父子传值、slot插槽
插槽传值
<slot title=“123” name=“aaa”></slot>
父组件接收插槽值
<div slot=“aaa” slot-scope=“props” :value=“props.title”></div>
示例步骤
1、在components文件夹下新建一个MyComponent1文件夹,新建MyCompont1.vue
(以btn为例)
<template> <el-button-group> <el-button v-for="(btn,index) in this.buttons" :key="index" :type="btn.type ? btn.type:'primary'" :icon="btn.icon" :size="btn.size?btn.size:'mini'" @click="btn.click" > {{btn.label}} </el-button> </el-button-group> </template>
<script> export default { name: 'MyComponent1', // name就是封装好后使用的组件名 props: { buttons: { type: Array, required: true } } } </script>
2、components文件夹下新建index.js, 用于注册组件,也可以在main.js中注册,为了统一管理建议放在components中注册
3、然后main.js中引入,就可以直接使用了**
注册
import Vue from 'vue' import MyComponent1 from './MyComponent1/index.vue' //多个组件就多次注册 Vue.component(MyComponent1.name, MyComponent1) ''
使用
<template> <div> <MyComponent1 :buttons="buttons"></MyComponent1> </div> </template>
<script> export default { name: '', data () { return { buttons: [{ label:'创建', icon:'el-icon-circle-plus-outline', click: ()=>{console.log('创建')} },{ label:'修改', icon:'el-icon-edit-outline', click: ()=>{console.log('修改')} }] } } } </script>
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue+watermark-dom实现页面水印效果(示例代码)
watermark.js 是基于 DOM 对象实现的 BS 系统的水印,确保系统保密性,安全性,降低数据泄密风险,简单轻量,支持多属性配置,本文将通过 vue 结合 watermark-dom 库,教大家实现简单而有效的页面水印效果,感兴趣的朋友跟随小编一起看看吧2024-07-07vue前端获取/切换麦克风、播放采集音频和采集音量大小完整代码
这篇文章主要给大家介绍了关于vue前端获取/切换麦克风、播放采集音频和采集音量大小的相关资料,文中通过图文以及代码介绍的非常详细,对大家学习或者使用vue具有一定的参考借鉴价值,需要的朋友可以参考下2023-12-12
最新评论