婷婷久久综合九色综合,欧美成色婷婷在线观看视频,偷窥视频一区,欧美日本一道道一区二区

<tt id="bu9ss"></tt>
  • <span id="bu9ss"></span>
  • <pre id="bu9ss"><tt id="bu9ss"></tt></pre>
    <label id="bu9ss"></label>

    當前位置:首頁 >  站長 >  編程技術 >  正文

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

     2020-11-19 15:22  來源: 腳本之家   我來投稿 撤稿糾錯

      阿里云優(yōu)惠券 先領券再下單

    這篇文章主要介紹了在vue中通過render函數(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 本身是作為渲染結果被創(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)過測試正常使用是沒問題的。現(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名]+方法屬性

    代碼結構:

    // 父組件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元素層級分析總結:

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

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

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

    來源:腳本之家

    鏈接:https://www.jb51.net/article/199904.htm

    申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

    相關文章

    • Vue 3自定義指令開發(fā)的相關總結

      這篇文章主要介紹了Vue3自定義指令開發(fā)的相關總結,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下

      標簽:
      vue.js
    • vue集成一個支持圖片縮放拖拽的富文本編輯器

      文章主要介紹了vue集成一個支持圖片縮放拖拽的富文本編輯器,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下。

      標簽:
      vue.js
    • vue自定義組件實現(xiàn)雙向綁定

      這篇文章主要為大家詳細介紹了vue自定義組件實現(xiàn)雙向綁定,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

      標簽:
      vue.js
    • Vue實現(xiàn)隨機驗證碼功能

      這篇文章主要為大家詳細介紹了Vue實現(xiàn)隨機驗證碼功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

      標簽:
      vue.js
    • vue實現(xiàn)樹狀表格效果

      這篇文章主要為大家詳細介紹了vue實現(xiàn)樹狀表格效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

      標簽:
      vue.js

    熱門排行

    信息推薦