实现效果:点击书本弹出dialog层,
v-if=selected
控制显示隐藏;初始化时:
selected: undefined
,dialog层不渲染;点击触发:点击时,
selected=book
,dialog层开始渲染的同时调用dialog的子方法
,这时dialog层可能还没有初始化完成
,所以报undefined错误。解决方法:
加延时处理
preview (book) {
this.selected = book
setTimeout(() => {
this.$refs.dialog.open()
}, 10)
}