记录element bug issuei:el-dialog的close事件有bug:导致回调方法被执行了两次

el-dialog的close事件有bug:导致回调方法被执行了两次

目前最新版本2.13.2依旧存在这个问题!

问题:el-dialog的close事件有bug:导致回调方法被执行了两次
场景:如果@close的回掉方法(@close=cancel)和取消按钮@click的回调方法(@click=cancel)相同,当点击取消按钮的时候,对应的回调就会被执行两次。如果将@close=cancel改成@click.native=cancel就不会。所以@close封装有问题!【还有这个网址https://elementui.github.io/issue-generator根本访问不了...】
```
<template>
    <div class="test-el-dialog">
        <el-button type="text" @click="dialogVisible = true">点击打开 Dialog</el-button>

        <el-dialog
                title="提示"
                :visible.sync="dialogVisible"
                width="30%"
                @close="cancel">
            <span>这是一段信息</span>
            <span slot="footer" class="dialog-footer">
                <el-button @click="cancel">取 消</el-button>
                <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
            </span>
        </el-dialog>
    </div>
</template>

<script>
    export default {
        name: 'TestElDialog',
        data () {
            return {
                dialogVisible: false
            }
        },
        methods: {
            cancel () {
                this.dialogVisible = false
            }
        }
    }
</script>
```
 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
el-dialogclose回调函数是在用户点击关闭图标或遮罩关闭Dialog时触发的。可以在该回调函数中添加相关逻辑。例如,在before-close属性中指定一个方法,该方法会在关闭Dialog之前执行。在这个方法中,可以进行一些操作,比如弹出确认框,然后根据用户的选择来决定是否关闭Dialog。\[1\] 在示例代码中,可以看到handleClose方法被指定为before-close回调函数。在这个方法中,使用了this.$confirm方法来弹出一个确认框,用户点击确认后调用done()方法来关闭Dialog。如果用户点击取消,则不执行任何操作,Dialog保持打开状态。\[1\] 另外,如果在Dialog中使用了带有prop属性的el-input元素,它们会参与字段的校验。当关闭Dialog再次打开时,可能会发现校验的错误信息仍然保留在表单中。为了解决这个问题,可以在Dialog关闭时重置表单的校验规则。可以通过在close事件中调用$refs.dialogForm.resetFields()方法来实现。这样,每次关闭Dialog时,表单的校验规则都会被清除,下次打开Dialog时就不会显示之前的错误信息了。\[2\] 总结起来,el-dialogclose回调函数可以用来执行一些在关闭Dialog之前需要处理的逻辑,比如弹出确认框、清除表单的校验规则等。\[1\]\[2\] #### 引用[.reference_title] - *1* [el-dialog的before-close](https://blog.csdn.net/ZMJ_QQ/article/details/120280746)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [ElementUI dialog配合form,关闭dialog时清除校验](https://blog.csdn.net/qq_25857899/article/details/117702556)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [记录element bug issueiel-dialogclose事件bug导致回调方法执行两次](https://blog.csdn.net/LiyangBai/article/details/107761134)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明致成

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值