这里有三点需要说明:

1. 使用:before-close="closeHandle" 将其 $emit() 出去

2. 取消按钮 也需要$emeit出去

3. 控制对话框显示隐藏的变量需要props给父组件来传值,这个相当重要,不然控制不了对话框的显示隐藏

4.1,2步骤是为了在子组件不再重复操作显示隐藏的变量,vue会报错

现在看代码:

对话框子组件:

<el-dialog
:title="dialogTitle"
:visible.sync="createDialog"
width="544px"
center
custom-class="dialogStyle"
:before-close="handleClose">
<el-form ref="pushForm" label-position="right" :model="pushForm" :rules="Rules" label-width="100px">
<el-form-item label="URL" prop="url">
<el-input placeholder="请输入URL链接" clearable v-model="pushForm.url"></el-input>
</el-form-item>
<el-form-item label="备注" prop="depicts">
<el-input
type="textarea"
:rows="4"
placeholder="请输入备注内容(255字符以内)"
v-model="pushForm.depicts"
maxlength="255">
</el-input>
</el-form-item>
<el-form-item label="是否启用" prop="isEnable">
<el-radio-group v-model="pushForm.isEnable">
<el-radio :label="0">启用</el-radio>
<el-radio :label="1">禁用</el-radio>
</el-radio-group>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="handleClose">取 消</el-button>
<el-button type="primary" @click="submitPushForm">确 定</el-button>
</div>
</el-dialog>
export default {
name: '',
props: {
title: {
type: String,
default: ''
},
createDialog: {
type: Boolean
}
// pushDataList: {
// type: Array,
// // default: []
// }
}, ....
methods: {
addDialog (sign, item) {
// this.createDialog = true
this.$emit('opendialog')
this.dialogTitle = sign + this.title
this.typeNum = item.type
this.reMark = sign
},
editDialog (sign, item) {
// this.createDialog = true
this.$emit('opendialog')
this.dialogTitle = sign + this.title
this.typeNum = item.type
this.reMark = sign
},
submitPushForm () {
this.$refs.pushForm.validate((valid) => {
if (valid) {
console.log(this.pushForm)
this.pushForm.type = this.typeNum
if (this.reMark === '添加') {
this.$emit('addPushHandle', this.pushForm)
} else if (this.reMark === '编辑') {
this.$emit('updatePushHandle', this.pushForm)
}
} else {
console.log('error submit!')
}
})
},
handleClose () {
this.$emit('closeDialog') // 取消和 x 按钮的事件,防止重复操作createDialog变量
 }, }

父组件:

<push-data :title="title" :createDialog="createDialog" @opendialog="opendialog" @addPushHandle="addPushHandle" @updatePushHandle="updatePushHandle" @closeDialog="closeHandle"></push-data>

data () {
return {
title: '应用推送',
createDialog: false
}
},
methods: {
opendialog () {
this.createDialog = true
},
addPushHandle (form) {
// console.log('添加应用推送')
// console.log(form)
// console.log(this.applicationId)
let params = Object.assign({},form,{applicationId: this.applicationId})
console.log(params)
this.createDialog = false // 亲测。操作dialog可以生效
},
updatePushHandle (form) {
console.log('编辑应用推送')
applicationPushUpdate().then((res) => { }).catch((err) => { })
},
closeHandle () {
this.createDialog = false // 控制取消和X按钮,关闭弹窗
}

以上就是个人总结,如果小伙伴有更好的方法,欢迎留言交流哦!!!^_^

elementUI 的el-dialog作为子组件,父组件如何控制其关闭的按钮的更多相关文章

  1. vue 组件-父组件传值给子组件

    父组件通过属性,传值给子组件,子组件通过,props数组里的名称来接受父组件传过来的值. HTML部分: <div id="app"> <tmp1 :parent ...

  2. Angular组件——父组件调用子组件方法

    viewChild装饰器. 父组件的模版和控制器里调用子组件的API. 1.创建一个子组件child1里面只有一个greeting方法供父组件调用. import { Component, OnIni ...

  3. vue2.0 子组件 父组件之间的传值

    常用的子组件给父组件传值/调父组件方法 //子组件let val = "";//可以是任意类型this.$emit('fatherFun', val); //父组件<fath ...

  4. vue 【 子子组件 => 子组件 => 父组件 】 的事件和参数的传递

    1,子子组件  TodoItem.vue     <template>   <div class="todo-item" :class="{'is-co ...

  5. 学以致用 ---- vue子组件→父组件通信

    之前写过一篇关于 vue2.0中v-on绑定自定义事件 的随笔,但是今天实际应用的时候才发现根本就不理解,下面是实际工作中遇到的问题: [情景描述]页面中的[下拉搜索组件],因为多个页面中用到,所以抽 ...

  6. vuejs2.0子组件改变父组件的数据

    在vue2.0之后的版本中,不允许子组件直接改变父组件的数据,在1.0的版本中可以这样操作的,但是往往项目需求需要改变父组件的数据,2.0也是可一个,区别是,当我们把父元素的数据给子组件时,需要传一个 ...

  7. vue父组件访问子组件

    1.父组件(父组件访问子组件的方法drop) <!--父组件访问子组件的方法v-ref:shopcart--> <template> <div id="pare ...

  8. Vue父组件向子组件传值以及data和props的区别

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/xukongjing1/article/ ...

  9. Vue父组件像子组件传值--自定义属性

    这里有个注意的地方,Vue实例控制app DIV 大组件,我们在div中天加小组件的时候,传值需要创建自定义的属性 之后在通过props:[‘属性名’] 来把父元素data中的数据传递给子组件 < ...

随机推荐

  1. .net core jenkins持续集成

    执行 Shell pwd ls echo ${PATH} whoami which dotnet dotnet --info dotnet --version echo '============== ...

  2. 数据分析之sklearn

    一,介绍 Python 中的机器学习库 简单高效的数据挖掘和数据分析工具 可供大家使用,可在各种环境中重复使用 建立在 NumPy,SciPy 和 matplotlib 上 开放源码,可商业使用 - ...

  3. cmdb资产管理2

    新增资产 现在api服务端已经能获取到我们要做的操作了.接下来应该是补充获取操作后对应的程序编写 我们要做的是把post请求发过来的数据保存到数据库.我们创建repository 名字的app,并设计 ...

  4. SpringCloud2.0 Hystrix Dashboard 断路器指标看板 基础教程(八)

    1.启动基础工程 1.1.启动[服务中心]集群,工程名称:springcloud-eureka-server 参考 SpringCloud2.0 Eureka Server 服务中心 基础教程(二) ...

  5. The Sum of the k-th Powers(Educational Codeforces Round 7F+拉格朗日插值法)

    题目链接 传送门 题面 题意 给你\(n,k\),要你求\(\sum\limits_{i=1}^{n}i^k\)的值. 思路 根据数学知识或者说题目提示可知\(\sum\limits_{i=1}^{n ...

  6. 由Catalan数所引出的

    百度一番: 历史 ·1758年,Johann Segner 给出了欧拉问题的递推关系: ·1838年,研究热潮: –GabrielLame给出完整证明和简洁表达式: –EugèneCharlesCat ...

  7. LGOJP2051 [AHOI2009]中国象棋

    比较明显的计数dp.不知道为什么被打了状压的tag... 不难发现无论炮放在哪里其实是等价的,需要知道的只有这一列放了一个炮还是两个炮还是还没放,那么可以设\(f[i,j,k]\)表示第\(i\)行, ...

  8. Alpha冲刺随笔八:第八天

    课程名称:软件工程1916|W(福州大学) 作业要求:项目Alpha冲刺(十天冲刺) 团队名称:葫芦娃队 作业目标:在十天冲刺里对每天的任务进行总结. 随笔汇总:https://www.cnblogs ...

  9. Dubbo源码分析:Server

    Server接口是开启一个socket服务.服务实现有netty,mina,grizzly的. 抽象时序图 获取NettyServer时序图 Transporter类图 Server 类图

  10. Java web开发——文件夹的上传和下载

    我们平时经常做的是上传文件,上传文件夹与上传文件类似,但也有一些不同之处,这次做了上传文件夹就记录下以备后用. 这次项目的需求: 支持大文件的上传和续传,要求续传支持所有浏览器,包括ie6,ie7,i ...