Vue 里怎样在 Render 中使用 $refs

欢迎点击领取 -《前端面试题进阶指南》:前端登顶之巅-最全面的前端知识点梳理总结

*分享一个使用比较久的链接

在这里插入图片描述

背景:

使用 element-ui 组件,发现el-popover组件有一个方法: doClose();调用方法为:this. r e f s [ n a m e ] . d o C l o s e ( ) ;经过测试正常使用是没问题的。现在想要在组件内的 r e n d e r 函数中调用,一直获取不到 t h i s . refs[name].doClose();经过测试正常使用是没问题的。 现在想要在组件内的render函数中调用,一直获取不到this. refs[name].doClose();经过测试正常使用是没问题的。现在想要在组件内的render函数中调用,一直获取不到this.refs[name],报undefined

解决思路:
  1. 添加vue-DevTools工具,查看$refs属性下是否存在该元素,分析Dom元素存在的位置,进行逐层分解
  2. 打印当前render下的this,发现并没有当前元素的相关属性,so: this指向没有问题,但并非是我们的Dom元素
  3. 理解Vue.component和render所创建的组件的关系和指向问题,render相当于是在当前的父组件内创建了子组件
  4. 解决方式:this.$refs[父组件ref名].refs[子组件ref名]+方法属性
代码结构:
// 父组件TableList内的属性
<template>
  <el-card class="auto-schedu-class">
    <TableList border ref="TableList" :columns="columns(this)" />
  </el-card>
</template>
  
<script>
const columns = that => [
  {
    render: (h, parmas) => {
      return h(
        "el-popover",
        {
          ref: "popover",
          props: {
            placement: "top",
            width: "160"
          }
        },
        [
          h("p", "当前规则生效中,是否确认删除?"),
          [
            h(
              "el-button",
              {
                props: {
                  type: "text",
                  size: "mini"
                },
                on: {
                  click: row => {
                    console.log(this, "-------------");
                    that.handleDeleteRow(row);
                  }
                }
              },
              "取消"
            ),
            h(
              "el-button",
              {
                props: {
                  type: "text",
                  size: "mini"
                }
              },
              "确定"
            )
          ],
          h(
            "el-button",
            {
              props: {
                type: "text",
                size: "mini"
              },
              slot: "reference"
            },
            "删除"
          )
        ]
      );
    }
  }
];
export default {
  data() {
    return {
      columns
    };
  },
  methods: {
    handleDeleteRow(row) {
      console.log(this, "=======");
      this.$refs.TableList.$refs.popover.doClose(); // 获取到子组件内的属性方法
    }
  }
};
</script>
vue-DevTools元素层级分析总结:

在这里插入图片描述
在这里插入图片描述

  • 作者也看了好多类似的文章,并没有找到一个合理的解决方式和解析文章
  • 通过我们的vue工具,逐层进行元素的拆解,证明我们的refs元素是存在的,so:Dom的一种解析加载方式和层级关系就是我们的一个思路点,很多文章归结在this的指向上面,而render的创建和vue.component的关系才是我们的突破点
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SunnyRun!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值