版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/shelbyandfxj/article/details/82658363
const deleteButton = (vm, h, currentRow, index) => {
return h('Poptip', {
props: {
ref: 'poptip',
placement: 'left',
title: '您确定要删除这条数据吗?',
transfer: true,
confirm: true,
},
on: {
"on-ok": () => {
vm.deleteData([currentRow.id]);
}
}
}, [
h('Button', {
props: {
type: 'error',
icon: 'trash-a',
size: 'small'
},
style: {
margin: '0 3px'
}
}, '删除')
])
};
如上代码,在h函数中使用ref,但是使用this.$refs没有找到poptip,为什么呢?
找了refs和h的资料,先来了解ref和h。
我们常见h函数的用法是:
render: (h) => {
return h(ele)
}
=> 是es6的用法,相当于 (h) => {} 相当于 function(){}。 Vue中有一个createElement参数,而h相当于createElement,因此上面的代码可解析为:
render: function(createElement) {
return createElement(ele);
}
Vue在创建Vue实例时,通过render作为函数来渲染Dom树,而在render方法中,又调用createElement函数来渲染子组件或元素。因此此时元素或子组件处于渲染过程。
ref是用来给元素或子组件注册引用信息的,引用信息将会注册在父组件的$refs对象上。因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!
了解了h和ref的作用之后,就可以知道了,h是作用在渲染的时候的,而ref是渲染之后才创建的,因此在h函数中使用ref是无效的。
参考资料:https://cn.vuejs.org/v2/api/#ref
https://cn.vuejs.org/v2/guide/render-function.html#createElement-%E5%8F%82%E6%95%B0