乱码乱a∨中文字幕,在线免费激情视频,亚洲欧美久久夜夜潮,国产在线网址

  1. <sub id="hjl7n"></sub>

    1. <sub id="hjl7n"></sub>

      <legend id="hjl7n"></legend>

      當(dāng)前位置:首頁 >  站長 >  編程技術(shù) >  正文

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

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

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

      這篇文章主要介紹了在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的用法,相當(dāng)于 (h) => {} 相當(dāng)于 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
         }
       
       }) 
      }

      補(bǔ)充知識: 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元素存在的位置,進(jìn)行逐層分解

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

      理解Vue.component和render所創(chuàng)建的組件的關(guān)系和指向問題,render相當(dāng)于是在當(dāng)前的父組件內(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", "當(dāng)前規(guī)則生效中,是否確認(rèn)刪除?"),
           [
            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工具,逐層進(jìn)行元素的拆解,證明我們的refs元素是存在的,so:Dom的一種解析加載方式和層級關(guān)系就是我們的一個思路點(diǎn),很多文章歸結(jié)在this的指向上面,而render的創(chuàng)建和vue.component的關(guān)系才是我們的突破點(diǎn)

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

      來源:腳本之家

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

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

      相關(guān)標(biāo)簽
      vue.js
      防止Vue閃現(xiàn)

      相關(guān)文章

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

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

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

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

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

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

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

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

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

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

        標(biāo)簽:
        vue.js

      熱門排行

      信息推薦