您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關vue中使用render函數(shù)如何實現(xiàn)給子組件設置ref,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
正常我們的寫法是,這樣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方法中,又調(diào)用createElement函數(shù)來渲染子組件或元素。
因此此時元素或子組件處于渲染過程。
ref是用來給元素或子組件注冊引用信息的,引用信息將會注冊在父組件的$refs對象上。
因為 ref 本身是作為渲染結(jié)果被創(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();調(diào)用方法為:this.refs[name].doClose();經(jīng)過測試正常使用是沒問題的?,F(xiàn)在想要在組件內(nèi)的render函數(shù)中調(diào)用,一直獲取不到this.refs[name].doClose();經(jīng)過測試正常使用是沒問題的。
現(xiàn)在想要在組件內(nèi)的render函數(shù)中調(diào)用,一直獲取不到this.refs[name].doClose();經(jīng)過測試正常使用是沒問題的。現(xiàn)在想要在組件內(nèi)的render函數(shù)中調(diào)用,一直獲取不到this.refs[name],報undefined
解決思路:
添加vue-DevTools工具,查看$refs屬性下是否存在該元素,分析Dom元素存在的位置,進行逐層分解
打印當前render下的this,發(fā)現(xiàn)并沒有當前元素的相關屬性,so: this指向沒有問題,但并非是我們的Dom元素
理解Vue.component和render所創(chuàng)建的組件的關系和指向問題,render相當于是在當前的父組件內(nèi)創(chuàng)建了子組件
解決方式:this.$refs[父組件ref名].refs[子組件ref名]+方法屬性
代碼結(jié)構(gòu):
// 父組件TableList內(nèi)的屬性 <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(); // 獲取到子組件內(nèi)的屬性方法 } } }; </script>
vue-DevTools元素層級分析總結(jié):
通過我們的vue工具,逐層進行元素的拆解,證明我們的refs元素是存在的,so:Dom的一種解析加載方式和層級關系就是我們的一個思路點,很多文章歸結(jié)在this的指向上面,而render的創(chuàng)建和vue.component的關系才是我們的突破點
關于vue中使用render函數(shù)如何實現(xiàn)給子組件設置ref就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。