色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

在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
相關文章:
主站蜘蛛池模板: 中文字幕成人在线观看 | 日本黄色美女网站 | 国产在线91精品天天更新 | 久艹在线观看 | 中文字幕人成不卡一区 | 欧美一级高清片 | 国产99高清一区二区 | 男女那个视频免费 | 222aaa天堂| 日韩一区二区在线视频 | gogo999亚洲肉体艺术大胆 | 国产成人a福利在线观看 | 国内精品一区二区2021在线 | 草草视频在线免费观看 | 大桥未久在线精品视频在线 | 美女三级在线 | 99久久精品国产片 | 国产夫妻视频 | 久久精品青草社区 | 中文字幕一区二区三区免费视频 | 精品日韩欧美一区二区三区在线播放 | 久草首页在线观看 | 久久精品国产亚洲片 | 久久有这有精品在线观看 | 精品国产美女福利到在线不卡 | 成人午夜视频在线播放 | 一级特黄特黄毛片欧美的 | 亚洲激情 欧美 | 成人免费看毛片 | 欧美成人精品在线 | 欧美日韩性视频一区二区三区 | 亚洲天堂中文网 | 国产一区二区精品久久凹凸 | 手机看片久久高清国产日韩 | 国产成人综合久久精品红 | 国产精品成人久久久久久久 | 国产伦精一区二区三区视频 | 澳门毛片免费观看 | 精品国产一区二区三区久久影院 | 亚洲精品一级片 | 日韩视频在线观看一区二区 |