el-dialog关闭后清空form表单(resetFields()方法不生效的原因及解决方法)
form表单属性resetFields不生效问题解决,el-dialog清空form内容,重置组件
官方文档属性
代码中使用
this.$refs.form.resetFields();
无论加在何处都不生效
解决方法(数据回显时添加$nextTick或者setTimeout)
edit(){
this.dialogFormVisible = true;
this.$nextTick(() => {
this.form = data;
})
}
或者
eidt() {
this.dialogFormVisible = true;
//回显数据
setTimeout(function(){
this.form = data;
}, 600);
}
el-dialog编辑,数据回显时不可以直接赋值,用$nextTick或者setTimeout包裹等待组件加载完毕
表单设置(添加ref及prop)
<el-form ref="form" :model="form" label-width="130px">
<el-row>
<el-col :span="8">
<el-form-item label="编码" prop="relatedcode">
<el-input v-model="form.relatedcode" disabled placeholder="请输入编码" clearable></el-input>
</el-form-item>
</el-col>
</el-row>
</el-form>
请看官方文档第二张图片属性解释
全部代码
<el-dialog title="数据处理" :visible.sync="dialogFormVisible" width="70%" @close="closeFun()">
<el-form ref="form" :model="form" label-width="130px">
<el-row>
<el-col :span="8">
<el-form-item label="编码" prop="relatedcode">
<el-input v-model="form.relatedcode" disabled placeholder="请输编码" clearable></el-input>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button size="medium" @click="dialogFormVisible = false">取 消</el-button>
<el-button size="medium" type="primary" @click="save">确 定</el-button>
</div>
</el-dialog>
methods: {
方法一://弹框关闭,重置表单(没有表单校验的提醒)
closeFun () {
this.$nextTick(() => {
// dom元素更新后执行,因此这里能正确打印更改之后的值
this.$refs.form.resetFields();
})
},
//编辑数据回显
edit(){
this.dialogFormVisible = true;
this.$nextTick(() => {
this.form = data;
})
}
方法二://有表单校验的提醒清空
closeFun () {
this.form= {};
this.$nextTick(() => {
this.$refs.form.clearValidate();
// dom元素更新后执行,因此这里能正确打印更改之后的值
});
},
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!