欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue2.x中$attrs的使用方法教程

 更新時(shí)間:2022年11月23日 14:55:37   作者:Geek喜多川  
正常情況下Vue推薦用props向子組件參數(shù),但是在特定場(chǎng)景下,使用$attrs會(huì)更方便,下面這篇文章主要給大家介紹了關(guān)于vue2.x中$attrs使用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

最近筆者在做大屏項(xiàng)目的時(shí)候,由于組件數(shù)據(jù)傳遞,一層傳遞一層,使用vuex或者pinia又顯得過于笨重。故而想起了那個(gè)傳說中的v-bind="$attrs"以及v-on="$listeners",下面就來聊下使用:

上圖組件之間的關(guān)系如下:

  • ComponentGrandParent為最外層父級(jí)組件(爺)

  • ComponentParent為中間層父級(jí)組件(父)

  • ComponentChild為子組件

ComponentGrandParent組件想把props傳遞給ComponentChild就通常需要在ComponentParent中通過屬性一個(gè)個(gè)的傳遞

//ComponentParent組件
<template>
  <ComponentChild :propa="prop1"
                  :propb="prop2"
                  :propc="prop3"
                  ...
  />
</template>

如果需要傳遞的屬性多,而且ComponentParent中沒有用到的ComponentGrandParent傳遞過來的屬性的時(shí)候,就很尷尬,很不優(yōu)雅,有時(shí)候還需要在寫watch監(jiān)聽傳遞過來的數(shù)據(jù),然后再賦值給data中的prop1,然后再傳遞給ComponentChild

使用$attrs能解決上述問題,那么什么是$attrs呢?

透?jìng)?Attributes 是指由父組件傳入,且沒有被子組件聲明為props或是組件自定義事件的 attributes 和事件處理函數(shù)。默認(rèn)情況下,若是單一根節(jié)點(diǎn)組件,$attrs 中的所有屬性都是直接自動(dòng)繼承自組件的根元素。

大白話講就是沒有父組件傳遞過來的props,在子組件中沒有對(duì)應(yīng)的props聲明,那么在子組件中就可以通過v-on:$attrs將父組件的props透?jìng)?/strong>給孫組件,在二次封裝一些elementui的組件有奇效

紙上得來終覺淺,下面來看下實(shí)際的使用,目錄結(jié)構(gòu)如下:

src
├─ blocks
│ └─ PassVal
│ ├─ components
│ │ └─ PassInput.vue
│ └─ PassVal.vue
├─ view
│ ├─ basic
│ │ └─ BasicView.vue
├─ App.vue
└─ main.js

  • BasicView.vue(父組件)中引入PassVal.vue(子組件);
  • PassVal.vue(子組件)中引入PassInput.vue(孫組件)
//BasicView.vue代碼如下:

<template>
  <div class="basic">
    <h3><i class="title_icon"></i>基礎(chǔ)知識(shí)</h3>
    <PassVal
      placeholder="我是placerholder"
      :clearable="true"
      :defaultVal="defaultVal"
      @changGrandChildVal="changGrandChildVal"
    />
  </div>
</template>

<script>
import PassVal from "@/blocks/PassVal/PassVal.vue";
export default {
  data() {
    return {
      defaultVal: "測(cè)試透?jìng)?,
    };
  },
  components: {
    PassVal,
  },
  methods: {
    /**
     * @function input值修改回調(diào)函數(shù)
     */
    changGrandChildVal(val) {
      console.log("PassInput組件的值變了", val);
    },
  },
};
</script>

<style scoped>
.basic {
  width: 100%;
  height: 100%;
}
</style>
  • PassVal想要傳遞三個(gè)屬性placeholder="我是placerholder" 、:clearable="true"以及:defaultVal="defaultVal"

接著來看下在PassVal中的處理:

//PassVal.vue
<template>
  <div class="passval">
    <el-divider content-position="left">1-$attr和 $listeners</el-divider>
    <div class="container">
      <div class="flex-two">
        <passInput v-bind="$attrs" v-on="$listeners"></passInput>
      </div>
    </div>
  </div>
</template>

<script>
import PassInput from "./components/PassInput.vue";
export default {
  components: {
    PassInput,
  },
  props: {
    defaultVal: {
      type: String,
      default: "輸入框默認(rèn)值",
    },
  },
};
</script>

<style scoped>
.passval {
  width: 100%;
  height: 100%;
}
</style>
  • 這里通過v-bind="$attrs"v-on="$listeners"將屬性和方法透?jìng)飨氯?/li>
  • 如果在PassVal.vue中有關(guān)于來自父組件BasicView.vue相關(guān)的props聲明,那么v-bind="$attrs"透?jìng)鞯膶傩詴?huì)將聲明的這個(gè)屬性剔除,透?jìng)饔嘞碌?code>porps屬性。
    • 例如:如果在PassVal.vue中的props中聲明defaultVal,那么父組件BasicView.vue傳遞過來的defaultVal將無法通過v-bind="$attrs"透?jìng)鹘o子組件PassInput.vue

而在PassInput.vue組件中

<template>
  <div class="pass-input">
    <el-input v-bind="$attrs" v-model="value" @input="inputHandler"></el-input>
  </div>
</template>

<script>
export default {
  name: "PassInput",
  created() {
    console.log("我是$attrs", this.$attrs);
    console.log("我是$listeners", this.$listeners);
  },
  data() {
    return {
      value: "",
    };
  },
  methods: {
    /**
     * @function el-input的輸入回調(diào)函數(shù)
     */
    inputHandler(val) {
      this.$emit("changGrandChildVal", val);
    },
  },
};
</script>

<style scoped>
.pass-input {
  width: 100%;
  height: 100%;
}
</style>

從而實(shí)現(xiàn)了優(yōu)雅的屬性透?jìng)?,在組件封裝中比較有用。

生命周期中的console.log("我是$attrs", this.$attrs)和console.log("我是$listeners", this.$listeners);以結(jié)果如下:

總結(jié)

到此這篇關(guān)于vue2.x中$attrs使用的文章就介紹到這了,更多相關(guān)vue2.x $attrs使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue中props用法介紹

    Vue中props用法介紹

    這篇文章主要給大家分享的是 Vue中props用法介紹,? 在Vue中通過props,可以將原本孤立的組件串聯(lián)起來,也就是可以子組件可以接收父組件傳遞過來的data,下面我們一起進(jìn)入文章看看內(nèi)容的詳細(xì)介紹吧,需要的朋友也可以參考一下
    2021-11-11
  • Vue樹表格分頁的實(shí)現(xiàn)方法詳解

    Vue樹表格分頁的實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了Vue樹表格分頁的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-10-10
  • vue實(shí)現(xiàn)滾動(dòng)底部加載下一頁指令的示例代碼

    vue實(shí)現(xiàn)滾動(dòng)底部加載下一頁指令的示例代碼

    vue中監(jiān)控滾動(dòng)事件可以直接在mounted中綁定滾動(dòng)事件,然后在銷毀前解綁滾動(dòng)事件,本文通過實(shí)例代碼介紹vue實(shí)現(xiàn)滾動(dòng)底部加載下一頁指令的過程,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • 使用kbone解決Vue項(xiàng)目同時(shí)支持小程序問題

    使用kbone解決Vue項(xiàng)目同時(shí)支持小程序問題

    這篇文章主要介紹了使用kbone解決Vue項(xiàng)目同時(shí)支持小程序問題,本文通過一個(gè)todo的例子跟大家詳細(xì)介紹,需要的朋友可以參考下
    2019-11-11
  • vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁加載

    vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁加載

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁加載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 對(duì)類Vue的MVVM前端庫的實(shí)現(xiàn)代碼

    對(duì)類Vue的MVVM前端庫的實(shí)現(xiàn)代碼

    這篇文章主要介紹了對(duì)類Vue的MVVM前端庫的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-09-09
  • 為Vue3?組件標(biāo)注?TS?類型實(shí)例詳解

    為Vue3?組件標(biāo)注?TS?類型實(shí)例詳解

    這篇文章主要為大家介紹了為Vue3?組件標(biāo)注?TS?類型實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決

    vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決

    這篇文章主要介紹了vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue提供的三種調(diào)試方式你知道嗎

    Vue提供的三種調(diào)試方式你知道嗎

    這篇文章主要為大家介紹了Vue提供的三種調(diào)試方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • vue項(xiàng)目中輪詢狀態(tài)更改方式(鉤子函數(shù))

    vue項(xiàng)目中輪詢狀態(tài)更改方式(鉤子函數(shù))

    這篇文章主要介紹了vue項(xiàng)目中輪詢狀態(tài)更改方式(鉤子函數(shù)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評(píng)論