鍍金池/ 問答/Python  HTML/ vue element-ui 第一次打開無法獲取dialog里的元素

vue element-ui 第一次打開無法獲取dialog里的元素

最近才接觸到vue和element.ui,發(fā)現(xiàn)element.ui里的dialog有一個(gè)問題不知道該怎么解決。
1、例如我在dialog里寫了一個(gè)表單組件,給表單組件設(shè)置了ref為form,在打開dialog的時(shí)候需要對(duì)里面的表單組件進(jìn)x行this.$ref['form'].resetFields(),來重置表單。
2、現(xiàn)在發(fā)現(xiàn)第一次打開dialog的時(shí)候,this.$ref['form']為undefined,關(guān)閉dialog,第二次打開之后就可以使用了。
3、有次在打開dialog的事件里寫了ajax請(qǐng)求,把重置表單的代碼寫在success回調(diào)里,就沒有問題了。
4、嘗試用了this.$nextTick(),沒有什么用。
希望能有大神看看有什么解決辦法。。蟹蟹

--------------------補(bǔ)充分割線-------------------------

dialog部分:

<el-dialog :visible.sync="dialogFormVisible" width="35%">
    <span slot="title" class="el-dialog__title">{{dialogTitle}}</span>
    <el-form :model="form" ref="roomForm" label-position="left" size="small">
    ...
    </el-form>
    <div slot="footer" class="dialog-footer">
    <el-button size="small" @click="dialogFormVisible = false;$refs['roomForm'].resetFields();">取 消</el-button>
    <el-button size="small" type="primary" @click="submitRoom('roomForm')">確 定</el-button>
    </div>
</el-dialog>

點(diǎn)擊事件js代碼:

modifyRoom(flag, data) {
let self = this;
self.dialogFormVisible = true; //控制dialog 顯示
...
// self.$refs[formName].resetFields(); //就是這句代碼,可以重置表單(讓表單內(nèi)容回到初始化狀態(tài),并清除驗(yàn)證信息)
}

就是我的頁面會(huì)有新建和修改兩個(gè)內(nèi)容,是用同一個(gè)dialog實(shí)現(xiàn)的,如果點(diǎn)擊了修改,就會(huì)把已有的數(shù)據(jù)填入表單內(nèi),如果點(diǎn)擊新建,就需要重置表單,將表單回復(fù)初始狀態(tài),但是第一次點(diǎn)擊新建的時(shí)候,他無法找到表單元素,就無法實(shí)現(xiàn)resetFields事件。只要打開一次dialog,第二次就不會(huì)報(bào)錯(cuò)了。
但是如果我把重置表單那句代碼放到ajax請(qǐng)求的success回調(diào)函數(shù)里,第一次也不會(huì)出錯(cuò)。

回答
編輯回答
心夠野

setTimeout(() => {

self.$refs[formName].resetFields()

}, 0)

2018年2月1日 00:46
編輯回答
孤影

樓主最后咋解決的,求分享

2017年10月20日 11:38
編輯回答
尐飯團(tuán)

看了好幾遍,老哥,貼出你的代碼吧

2018年4月13日 21:09