亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2020年11月17日 11:39:58   作者:千金一發(fā)  
這篇文章主要介紹了在vue中通過render函數(shù)給子組件設(shè)置ref操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

正常我們的寫法是,這樣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)過測試正常使用是沒問題的?,F(xiàn)在想要在組件內(nèi)的render函數(shù)中調(diào)用,一直獲取不到this.refs[name],報undefined

解決思路:

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

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

理解Vue.component和render所創(chuàng)建的組件的關(guān)系和指向問題,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的一種解析加載方式和層級關(guān)系就是我們的一個思路點,很多文章歸結(jié)在this的指向上面,而render的創(chuàng)建和vue.component的關(guān)系才是我們的突破點

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

相關(guān)文章

  • 關(guān)于ELement?UI時間控件el-date-picker誤差8小時的問題

    關(guān)于ELement?UI時間控件el-date-picker誤差8小時的問題

    本文探討了在使用Vue前端框架配合ElementUI開發(fā)時,遇到日期時間選擇器DateTimePicker的時間同步問題,通過揭示中國東八區(qū)與格林威治時間的時差,作者提供了設(shè)置value-format屬性的解決方案,以確保后端接收到的正確時間格式
    2024-08-08
  • Vue.js 實現(xiàn)tab切換并變色操作講解

    Vue.js 實現(xiàn)tab切換并變色操作講解

    這篇文章主要介紹了Vue.js 實現(xiàn)tab切換并變色操作講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • vue3組件庫添加腳本的實現(xiàn)示例

    vue3組件庫添加腳本的實現(xiàn)示例

    本文主要介紹了vue3組件庫添加腳本的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • vue獲取組件中元素寬度常用的方法

    vue獲取組件中元素寬度常用的方法

    在Web開發(fā)中,獲取DOM元素的寬度、高度以及滾動位移是常見的需求,這篇文章主要給大家介紹了關(guān)于vue獲取組件中元素寬度常用的方法,需要的朋友可以參考下
    2024-08-08
  • Vue3中provide和inject作用和場景

    Vue3中provide和inject作用和場景

    Vue3中provide和inject作用和場景是頂層組件向任意的底層組件傳遞數(shù)據(jù)和方法,實現(xiàn)跨層組件通信,本文通過實例介紹Vue3 provide和inject的相關(guān)知識,感興趣的朋友一起看看吧
    2023-11-11
  • vue前端獲取本地IP地址代碼實例

    vue前端獲取本地IP地址代碼實例

    再做前端頁面的時候,想獲取本地的ip地址,可能是為了和服務(wù)器通信,可能是為了展示,無論哪種,下面給大家總結(jié)下方法,這篇文章主要給大家介紹了關(guān)于vue前端獲取本地IP地址的相關(guān)資料,需要的朋友可以參考下
    2024-05-05
  • vue實現(xiàn)頁面滾動到底部刷新

    vue實現(xiàn)頁面滾動到底部刷新

    這篇文章主要為大家詳細介紹了vue實現(xiàn)頁面滾動到底部刷新,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • vue2實現(xiàn)簡易時鐘效果

    vue2實現(xiàn)簡易時鐘效果

    這篇文章主要為大家詳細介紹了vue2實現(xiàn)簡易時鐘效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • vue配置根目錄詳細步驟(用@代表src目錄)

    vue配置根目錄詳細步驟(用@代表src目錄)

    vue用@表示src文件夾,引入時找文件路徑更方便,下面這篇文章主要給大家介紹了關(guān)于vue配置根目錄(用@代表src目錄)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • element 動態(tài)合并表格的步驟

    element 動態(tài)合并表格的步驟

    這篇文章主要介紹了element 動態(tài)合并表格的步驟,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-12-12

最新評論