解决方法
直接不用这个@open方法,转而用@opened,代码例子:
- <el-dialog title="单个新增" :visible.sync="PlacardShowSingle" @opened="openpbSingle()" width="1100px" top="1%" :close-on-click-modal="false">
- <div style="margin:20px; margin-top: -20px;">
- <PbscheduleSingle ref="PbscheduleSingle"></PbscheduleSingle>
- </div>
- </el-dialog>
复制代码 方法例子:
- //弹窗完全挂载dom后再调用
- openpbSingle() {
- // 调用PbscheduleSingle组件的方法QueryPublishNumberQuantity
- this.$refs.PbscheduleSingle.QueryPublishNumberQuantity();
- },
复制代码 环境大抵是:
1.第一次打开没调用组件内部方法,发现是undefined,@open 在对话框打开之前触发,并且ref="bscheduleSingle",这个ref没挂载在dom,天然无法获取到相应的方法。
2.第二次打开,由于第一次打开,ref已经挂载在dom了,以是一切又正常了
3. @opened 在对话框完全打开之后触发,组件已经完全挂载,以是不会出现undefined的错误。
另有其他方法可以解决,但是这个应该是最简洁明白的吧。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |