千夜  
在一生的学习的过程中,发现学习我们急需使用或者能给我们及时带来价值的知识,我们会学的更加牢固,更加能坚持学习。

最近开发后台系统,需要调用子组件方法,思来想去,想到了refs,奈何在其中一个方法中可以正常调用,但是到了tab切换里面却报子组件方法未定义,一时半会没想到原因(也许是因为最近加班太多,脑容量不够了,哈哈),先上代码:

到这一步通过this.$refs.records.fetchTableData()无法调用<table-list-records>子组件的方法,控制台返回fetchTableData未定义,如下:

但是在同一个界面另一个方法中却能正常执行:

这里是在界面请求到用户详情数据之后才去调用fetchTableData方法。一开始并没有去想为什么这里可以在切换tab时就不能,后来想到可能是因为组件没有渲染完毕,果然,在tab切换的方法里面将 fetchTableData放到this.nextTick中之后,方法正常执行了!

百度了一番之后看到也有其他方法解决refs无法取到子组件的方法,比如加上setTimeout,但是这个方法有个弊端,就是无法准确判断什么时间页面加载完毕,把代码也贴出来吧:

这里建议还是使用this.$refs.nextTick,这样比较准确一点,就这样,共勉!

posted on 2021-01-17 12:25  jianzhenghui  阅读(2773)  评论(0编辑  收藏  举报