这里有三点需要说明:

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. sql 查询某个字段最长的记录

    sql  查询文本字段中值的长度最长的记录 一.函数1.SQL ServerLEN() 函数返回文本字段中值的长度.SELECT LEN(column_name) FROM table_name;2. ...

  2. zookeeper的安装使用

    转载从:https://blog.csdn.net/shenlan211314/article/details/6170717 一.zookeeper 介绍 ZooKeeper 是一个为分布式应用所设 ...

  3. springboot+vue2.x 解决session跨域失效问题

    服务端SpringBoot2.x   :localhost:8082 前端Vue2.x                 :localhost:81 前后端的端口号不同,为跨域,导致前端访问后端时,每次 ...

  4. MySQL MHA工作原理

    MHA工作组件 MHA(Master High Availability)是一种MySQL高可用解决方案,由日本DeNA公司开发,主要用于在故障切换和主从提升时进行快速切换,并最大程度保证数据一致性. ...

  5. 2018年第十届ACMICPC四川省大学程序设计竞赛

    ..拿金了 没给学校丢脸 A ....SB题啊 比赛的时候都没看 裸的一个bitset前缀和 先开一个1e4*1e4的二维bitset数组 初始第i个数组的值为1 << i (即B[i]= ...

  6. 项目Alpha冲刺--6/10

    项目Alpha冲刺--6/10 作业要求 这个作业属于哪个课程 软件工程1916-W(福州大学) 这个作业要求在哪里 项目Alpha冲刺 团队名称 基于云的胜利冲锋队 项目名称 云评:高校学生成绩综合 ...

  7. c++实用语法

    数组的快捷初始化 int inq[110] memset(inq, 0, sizeof(inq)); string到char数组的转换: string str ("Please split ...

  8. 让一个项目同时提交到码云和GitHub两个仓库

    在项目目录里找到.git文件夹然后找到config文件. 打开这个文件后找到下面的代码 [remote "origin"] url = git提交地址 fetch = +refs/ ...

  9. Tensorflow细节-P319-使用GPU基本的操作

    如果什么都不加,直接运行装了GPU的Tensorflow,结果是这样子的 import tensorflow as tf a = tf.constant([1.0, 2.0, 3.0], shape= ...

  10. LOJ P10004 智力大冲浪 题解

    每日一题 day37 打卡 Analysis 经典的带限期和罚款的单位时间任务调度问题 将 val 从大到小排序,优先处理罚款多的,将任务尽量安排在期限之前,并且靠后,如果找不到,则放在最后面 #in ...