电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

在vue中通過render函數給子組件設置ref操作

瀏覽:2日期:2022-10-26 14:18:41

正常我們的寫法是,這樣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
相關文章:
主站蜘蛛池模板: 考试试题_试卷及答案_诗词单词成语 - 优易学 | 合肥注册公司|合肥代办营业执照、2024注册公司流程 | 液氨泵,液化气泵-淄博「亚泰」燃气设备制造有限公司 | 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 污泥烘干机-低温干化机-工业污泥烘干设备厂家-焦作市真节能环保设备科技有限公司 | 走心机厂家,数控走心机-台州博城智能科技有限公司 | 烽火安全网_加密软件、神盾软件官网 | 威廉希尔WilliamHill·足球(中国)体育官方网站 | 至顶网| 气动调节阀,电动调节阀,自力式压力调节阀,切断阀「厂家」-浙江利沃夫自控阀门 | 减速机三参数组合探头|TSM803|壁挂式氧化锆分析仪探头-安徽鹏宸电气有限公司 | 中红外QCL激光器-其他连续-半导体连续激光器-筱晓光子 | 校车_校车价格_19座幼儿园校车_幼儿园校车_大鼻子校车 | 杭州月嫂技术培训服务公司-催乳师培训中心报名费用-产后康复师培训机构-杭州优贝姆健康管理有限公司 | 四川成都干燥设备_回转筒干燥机_脉冲除尘器_输送设备_热风炉_成都川工星科机电设备有限公司 | 郑州大巴车出租|中巴车租赁|旅游大巴租车|包车|郑州旅游大巴车租赁有限公司 | 诺冠气动元件,诺冠电磁阀,海隆防爆阀,norgren气缸-山东锦隆自动化科技有限公司 | 播音主持培训-中影人教育播音主持学苑「官网」-中国艺考界的贵族学校 | 实木家具_实木家具定制_全屋定制_美式家具_圣蒂斯堡官网 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | MOOG伺服阀维修,ATOS比例流量阀维修,伺服阀维修-上海纽顿液压设备有限公司 | 海外仓系统|国际货代系统|退货换标系统|WMS仓储系统|海豚云 | 奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌 | 广州企亚 - 数码直喷、白墨印花、源头厂家、透气无手感方案服务商! | 珠宝展柜-玻璃精品展柜-首饰珠宝展示柜定制-鸿钛展柜厂家 | 深圳APP开发公司_软件APP定制开发/外包制作-红匣子科技 | ERP企业管理系统永久免费版_在线ERP系统_OA办公_云版软件官网 | 防爆电机生产厂家,YBK3电动机,YBX3系列防爆电机,YBX4节防爆电机--河南省南洋防爆电机有限公司 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 纸箱抗压机,拉力机,脂肪测定仪,定氮仪-山东德瑞克仪器有限公司 | 管家婆-管家婆软件-管家婆辉煌-管家婆进销存-管家婆工贸ERP | 广西正涛环保工程有限公司【官网】| 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 船老大板材_浙江船老大全屋定制_船老大官网 | 热熔胶网膜|pes热熔网膜价格|eva热熔胶膜|热熔胶膜|tpu热熔胶膜厂家-苏州惠洋胶粘制品有限公司 | 杭州公司变更法人-代理记账收费价格-公司注销代办_杭州福道财务管理咨询有限公司 | 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛调查出轨取证公司_青岛婚外情取证-青岛探真调查事务所 | 滚筒烘干机_转筒烘干机_滚筒干燥机_转筒干燥机_回转烘干机_回转干燥机-设备生产厂家 | 书法培训-高考书法艺考培训班-山东艺霖书法培训凭实力挺进央美 | 深圳市宏康仪器科技有限公司-模拟高空低压试验箱-高温防爆试验箱-温控短路试验箱【官网】 |