在vue中通过render函数给子组件设置ref操作


Posted in Vue.js onNovember 17, 2020

正常我们的写法是,这样ref不会生效,h是作用在渲染的时候的,而ref是渲染之后才创建的,因此在h函数中使用ref是无效的。

render: (h, params) => {
       
 return h(expandRow, {
   ref:'child',
   props: {
     row: params.row
   }  
 })  
}

我们常见h函数的用法是:

render: (h) => {
  return h(ele)
}

=> 是es6的用法,相当于 (h) => {} 相当于 function(){},上面的代码可解析为:

render: function(createElement) {
  return createElement(ele);
}

Vue在创建Vue实例时,通过render作为函数来渲染Dom树,而在render方法中,又调用createElement函数来渲染子组件或元素。

因此此时元素或子组件处于渲染过程。

ref是用来给元素或子组件注册引用信息的,引用信息将会注册在父组件的$refs对象上。

因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!

解决办法

把h改为创建 this.$createElement

render: (h, params) => {
       
 return this.$createElement(expandRow, {
   ref:'child',
   props: {
     row: params.row
   }
  
 })  
}

补充知识:Vue 里怎样在 Render 中使用 $refs

背景:

使用 element-ui 组件,发现el-popover组件有一个方法: doClose();调用方法为:this.refs[name].doClose();经过测试正常使用是没问题的。现在想要在组件内的render函数中调用,一直获取不到this.refs[name].doClose();经过测试正常使用是没问题的。

现在想要在组件内的render函数中调用,一直获取不到this.refs[name].doClose();经过测试正常使用是没问题的。现在想要在组件内的render函数中调用,一直获取不到this.refs[name],报undefined

解决思路:

添加vue-DevTools工具,查看$refs属性下是否存在该元素,分析Dom元素存在的位置,进行逐层分解

打印当前render下的this,发现并没有当前元素的相关属性,so: this指向没有问题,但并非是我们的Dom元素

理解Vue.component和render所创建的组件的关系和指向问题,render相当于是在当前的父组件内创建了子组件

解决方式: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中通过render函数给子组件设置ref操作

在vue中通过render函数给子组件设置ref操作

作者也看了好多类似的文章,并没有找到一个合理的解决方式和解析文章

通过我们的vue工具,逐层进行元素的拆解,证明我们的refs元素是存在的,so:Dom的一种解析加载方式和层级关系就是我们的一个思路点,很多文章归结在this的指向上面,而render的创建和vue.component的关系才是我们的突破点

以上这篇在vue中通过render函数给子组件设置ref操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
在Vue中使用Echarts可视化库的完整步骤记录
Nov 18 Vue.js
Vue Elenent实现表格相同数据列合并
Nov 30 Vue.js
Vue 组件注册全解析
Dec 17 Vue.js
Vue实现省市区三级联动
Dec 27 Vue.js
Vue常用API、高级API的相关总结
Feb 02 Vue.js
基于vue的video播放器的实现示例
Feb 19 Vue.js
vue项目配置 webpack-obfuscator 进行代码加密混淆的实现
Feb 26 Vue.js
vue-cropper插件实现图片截取上传组件封装
May 27 Vue.js
vue中利用mqtt服务端实现即时通讯的步骤记录
Jul 01 Vue.js
vue实现移动端div拖动效果
Mar 03 Vue.js
VUE递归树形实现多级列表
Jul 15 Vue.js
Vue3实现简易音乐播放器组件
Aug 14 Vue.js
vue中音频wavesurfer.js的使用方法
Feb 20 #Vue.js
vue使用vant中的checkbox实现全选功能
Nov 17 #Vue.js
vue+vant实现购物车全选和反选功能
Nov 17 #Vue.js
vue+iview分页组件的封装
Nov 17 #Vue.js
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 #Vue.js
vue+iview实现分页及查询功能
Nov 17 #Vue.js
vue中echarts的用法及与elementui-select的协同绑定操作
Nov 17 #Vue.js
You might like
一周让你学会PHP 不错的学习资料
2009/02/06 PHP
php提示无法加载或mcrypt没有找到 PHP 扩展 mbstring解决办法
2012/03/27 PHP
Yii2 assets清除缓存的方法
2016/05/16 PHP
WordPress过滤垃圾评论的几种主要方法小结
2016/07/11 PHP
Thinkphp5 微信公众号token验证不成功的原因及解决方法
2017/11/12 PHP
避免回车键导致的页面无意义刷新的解决方法
2011/04/12 Javascript
映彩衣的js随笔(js图片切换效果)
2011/07/31 Javascript
Highcharts 非常实用的Javascript统计图demo示例
2013/07/03 Javascript
js之事件冒泡和事件捕获详细介绍
2013/10/28 Javascript
jQuery中trigger()方法用法实例
2015/01/19 Javascript
javascript中基本类型和引用类型的区别分析
2015/05/12 Javascript
jQuery+HTML5美女瀑布流布局实现方法
2015/09/21 Javascript
基于Jquery和html5的7款个性化地图插件
2015/11/17 Javascript
js实现的二分查找算法实例
2016/01/21 Javascript
常用原生JS兼容性写法汇总
2016/04/27 Javascript
nodejs中sleep功能实现暂停几秒的方法
2017/07/12 NodeJs
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
2018/06/14 Javascript
layer弹出层父子页面事件相互调用方法
2018/08/17 Javascript
微信小程序websocket聊天室的实现示例代码
2019/02/12 Javascript
vue中img src 动态加载本地json的图片路径写法
2019/04/25 Javascript
node.js基础知识汇总
2020/08/25 Javascript
Js Snowflake(雪花算法)生成随机ID的实现方法
2020/08/26 Javascript
python获取文件后缀名及批量更新目录下文件后缀名的方法
2014/11/11 Python
修改python plot折线图的坐标轴刻度方法
2018/12/13 Python
通过cmd进入python的实例操作
2019/06/26 Python
基于plt.title无法显示中文的快速解决
2020/05/16 Python
python如何对链表操作
2020/10/10 Python
Python截图并保存的具体实例
2021/01/14 Python
美国知名平价彩妆品牌:e.l.f. Cosmetics
2017/11/20 全球购物
学生会宣传部部长竞选演讲稿
2014/04/25 职场文书
Python 线程池模块之多线程操作代码
2021/05/20 Python
JavaScript组合继承详解
2021/11/07 Javascript
一文弄懂MySQL索引创建原则
2022/02/28 MySQL
SpringBoot2零基础到精通之数据与页面响应
2022/03/22 Java/Android
Go语言grpc和protobuf
2022/04/13 Golang
Win11如何默认打开软件界面最大化?Win11默认打开软件界面最大化的方法
2022/07/15 数码科技