element-ui|element-ui 弹窗组件封装 极简方案
封装el-dialog
为一个组件
【element-ui|element-ui 弹窗组件封装 极简方案】我们在使用element-ui
的时候,如果一个弹窗中的内容很多,那么我们经常会把这个弹窗封装成一个组件,如下:
弹窗内容
// DetailDialog.vue js
el-dialog
会修改 props,并报错但是这样会有一个问题,当触发了
el-dialog
内部的关闭事件时, 比如点击弹窗阴影等, 它会emit
事件来修改当前组件的props [visible]
,由于组件不能直接修改prop
属性,然后就会报错。我们新增了一个中间变量
innerVisible
,来拦截props [visible]
的修改和获取
弹窗内容
// DetailDialog.vue js
这样在
el-dialog
内部修改prop[visible]
的时候,我们会通过emit('update:')
的方式来通知父组件,避免直接修改props。当然父组件需要加上sync修饰符来接受修改:
到此为止,封装的弹窗组件已经没有问题了。
继续优化,使用v-model控制显示隐藏
// DetailDialog.vue js
接入了
v-model
,使用起来就更高大上而且整洁了
继续优化,封装成mixins
当频繁封装弹窗组件时,那么上述逻辑也需要不停地复制,所以继续优化,把上述控制显示隐藏的逻辑封装成了
mxins
,直接复用即可// vModelDialog.js
export default {
model: {
prop: 'visible',
event: 'toggle'
},
props: {
visible: {
type: Boolean,
default: () => {
return false
}
}
},
computed: {
innerVisible: {
get: function() {
return this.visible
},
set: function(val) {
this.$emit('toggle', val)
}
}
}
}
那么封装弹窗插件时,只需引入
mixins
即可完成显示隐藏逻辑。// DetailDialog.vue js
推荐阅读
- Nuxt.js-手写一个分页组件
- vue|Vue + ElementUI+ el-autocomplete 组件的防抖方案的懒加载
- AVM 拖动组件 movable-view 介绍
- 前端|9.06 Day47---Element UI局部组件库的使用
- vue3父组件和子组件如何传值实例详解
- vue3自定义组件之v-model实现父子组件双向绑定
- vue|vue 组件异步加载方式(按需加载)
- OpenDataV低代码平台新增组件流程
- 移动端|微信小程序组件封装-如何进行属性判断
- 使用element-ui中的el-radio(单选框)组件实现选中和取消选中功能