vue 在h函数中添加ref无效的原因

   const deleteButton = (vm, h, currentRow, index) => {
        return h('Poptip', {
            ref: 'poptip',
            props: {
                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

vue Render:h=>h(App) 解析

https://cn.vuejs.org/v2/guide/render-function.html#%E6%B7%B1%E5%85%A5%E6%95%B0%E6%8D%AE%E5%AF%B9%E8%B1%A1

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值