日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

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

正常我們的寫法是,這樣ref不會生效,h是作用在渲染的時候的,而ref是渲染之后才創(chuàng)建的,因此在h函數(shù)中使用ref是無效的。

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

我們常見h函數(shù)的用法是:

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

=> 是es6的用法,相當于 (h) => {} 相當于 function(){},上面的代碼可解析為:

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

Vue在創(chuàng)建Vue實例時,通過render作為函數(shù)來渲染Dom樹,而在render方法中,又調用createElement函數(shù)來渲染子組件或元素。

因此此時元素或子組件處于渲染過程。

ref是用來給元素或子組件注冊引用信息的,引用信息將會注冊在父組件的$refs對象上。

因為 ref 本身是作為渲染結果被創(chuàng)建的,在初始渲染的時候你不能訪問它們 - 它們還不存在!

解決辦法

把h改為創(chuàng)建 this.$createElement

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

補充知識:Vue 里怎樣在 Render 中使用 $refs

背景:

使用 element-ui 組件,發(fā)現(xiàn)el-popover組件有一個方法: doClose();調用方法為:this.refs[name].doClose();經(jīng)過測試正常使用是沒問題的。現(xiàn)在想要在組件內的render函數(shù)中調用,一直獲取不到this.refs[name].doClose();經(jīng)過測試正常使用是沒問題的。

現(xiàn)在想要在組件內的render函數(shù)中調用,一直獲取不到this.refs[name].doClose();經(jīng)過測試正常使用是沒問題的。現(xiàn)在想要在組件內的render函數(shù)中調用,一直獲取不到this.refs[name],報undefined

解決思路:

添加vue-DevTools工具,查看$refs屬性下是否存在該元素,分析Dom元素存在的位置,進行逐層分解

打印當前render下的this,發(fā)現(xiàn)并沒有當前元素的相關屬性,so: this指向沒有問題,但并非是我們的Dom元素

理解Vue.component和render所創(chuàng)建的組件的關系和指向問題,render相當于是在當前的父組件內創(chuàng)建了子組件

解決方式: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', '當前規(guī)則生效中,是否確認刪除?'), [ 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函數(shù)給子組件設置ref操作

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

作者也看了好多類似的文章,并沒有找到一個合理的解決方式和解析文章

通過我們的vue工具,逐層進行元素的拆解,證明我們的refs元素是存在的,so:Dom的一種解析加載方式和層級關系就是我們的一個思路點,很多文章歸結在this的指向上面,而render的創(chuàng)建和vue.component的關系才是我們的突破點

以上這篇在vue中通過render函數(shù)給子組件設置ref操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本va欧美va精品发布| 国产亚洲精品美女久久久久久久久久| 在线视频亚洲| 偷拍欧美精品| 美女精品一区| 国产丝袜一区| 国产精品黄色片| 亚洲成人va| 水蜜桃久久夜色精品一区的特点| 国产偷自视频区视频一区二区| 亚洲成人二区| 亚洲视频电影在线| 国产精品激情电影| 老司机精品在线| 亚洲第一精品影视| 青青草视频一区| 国产日韩一区二区三区在线| 欧美激情一区| 九色porny丨国产首页在线| 九九久久电影| 日本国产一区| 精品美女视频 | 日本天堂一区| 免费亚洲婷婷| 久久视频一区| 五月亚洲婷婷| 91精品精品| 国产精品毛片一区二区三区| 欧美日韩a区| 日韩精品午夜| 日本不卡在线视频| 亚洲播播91| 日本在线视频一区二区| 久久精品午夜| 视频一区视频二区在线观看| 欧美激情日韩| 欧美日韩精品一本二本三本| 久久精品国产99国产精品| 色在线视频观看| 日韩三级精品| 福利欧美精品在线| 日本视频一区二区| 日韩精品诱惑一区?区三区| 日韩精品一二区| 欧美www视频在线观看| 日韩精品视频网站| av中文资源在线资源免费观看| 日韩高清不卡一区| 亚洲女同av| 日本精品在线播放| 亚洲调教视频在线观看| 日韩av中文字幕一区二区三区| 国产伦久视频在线观看| 综合色一区二区| 99久久久久国产精品| 国产精品xxx| 亚洲一级特黄| 亚洲成人二区| 国产一区二区三区四区| 亚洲免费资源| 欧美日韩精品免费观看视欧美高清免费大片 | 91精品国产乱码久久久久久久| 日韩精品社区| 国产在线欧美| 国产福利片在线观看| 亚洲另类视频| 在线精品小视频| 吉吉日韩欧美| 国产精成人品2018| 奇米亚洲欧美| 日韩午夜电影| 亚洲福利免费| 肉色欧美久久久久久久免费看 | 美女久久一区| 欧美大黑bbbbbbbbb在线| 国产成人久久精品麻豆二区 | 伊人久久大香线蕉av不卡| caoporn视频在线| 免费在线欧美黄色| 国产亚洲一区| 91精品麻豆| 日产欧产美韩系列久久99| 在线亚洲一区| 亚洲少妇一区| 激情综合亚洲| 狠狠操综合网| 亚洲欧美伊人| 欧美高清不卡| 影院欧美亚洲| 欧美中文日韩| 蜜桃av一区二区三区电影| 男女精品网站| 综合国产视频| 日韩区一区二| 国产精品亚洲综合色区韩国| 国产精品一区二区美女视频免费看 | 日本午夜免费一区二区| 视频一区中文字幕精品| 蜜臀av性久久久久蜜臀aⅴ四虎| 红桃视频国产一区| 亚洲精品午夜av福利久久蜜桃| 欧美日韩国产一区二区三区不卡| 亚洲国产专区| 制服诱惑一区二区| 亚洲有吗中文字幕| 亚洲精品九九| 911精品国产| 久久av免费看| 日本不卡不码高清免费观看| 欧美综合社区国产| 美女高潮久久久| 日韩理论片av| 宅男噜噜噜66国产日韩在线观看| 免费在线看一区| 欧美精品中文| 狠狠躁少妇一区二区三区| 99精品综合| 伊人www22综合色| 国产麻豆一区| 久草免费在线视频| 欧美日韩一区二区综合| 蜜桃视频一区二区三区在线观看| 日本色综合中文字幕| 成人午夜毛片| 亚洲少妇自拍| 欧美精品二区| 久久高清免费| 五月国产精品| 精品视频在线观看网站| 日韩三区在线| 中文字幕av亚洲精品一部二部 | 蜜臀av国产精品久久久久| 欧美日韩伊人| 国产一区二区三区精品在线观看| 999国产精品视频| 日韩精品成人| 亚洲毛片视频| 日韩大片免费观看| 蜜桃视频在线观看一区二区| 老司机免费视频一区二区三区| 欧美综合另类| 国产精品一线| 亚洲作爱视频| 美女国产一区二区三区| 中文在线不卡| 精品精品99| 欧美资源在线| 国产精品99久久精品| 99亚洲视频| 久久三级中文| 亚洲三级国产| 午夜精品久久久久久久久久蜜桃| 亚洲一区二区三区免费在线观看 | 激情综合网站| 欧美国产三级| 麻豆精品91| 日韩中文在线播放| 国产精品自拍区| 久久亚洲欧洲| 久久久人人人| 久久国产乱子精品免费女| 久久精品国语| 久久99国产精品视频| 中文字幕日韩亚洲| 久久久久欧美精品| 久久av网址| 三级久久三级久久久| 激情久久久久久久| 国产一区二区三区四区大秀| 日本在线不卡视频一二三区| 久久网站免费观看| 精品国产美女a久久9999| 日本在线不卡视频| 久久av在线| 国产一区清纯| 国产精品伦理久久久久久| 日韩欧美激情电影| 男女男精品视频网| 女同性一区二区三区人了人一 | 亚洲天堂久久| 在线手机中文字幕| 国产丝袜一区| 日本精品一区二区三区在线观看视频| 欧美精品一线| 99免费精品| 中文字幕在线看片| 免费在线日韩av| 亚洲免费成人av在线| 尤物精品在线| 激情久久五月| 性欧美videohd高精| 精品一级视频| 国产精品成人国产| 青青草国产精品亚洲专区无| 亚洲人成网77777色在线播放 | 美女精品一区二区| 国产乱码精品一区二区三区四区 | 九九久久婷婷| 国产综合欧美| 亚洲午夜视频|