91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue中父組件如何給子組件傳值

發布時間:2021-08-18 10:46:00 來源:億速云 閱讀:158 作者:小新 欄目:web開發

小編給大家分享一下vue中父組件如何給子組件傳值,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一般情況下我們父子之間的傳值用的是props,這個就不多說了,但是如果想讓父給子組件的組件傳值怎么辦呢,這里我們就可以用到 provide 和 inject(依賴注入)

provide/inject需要一起使用,我們可以從父組件的provide傳值,子組件或者孫組件,就可以用inject來接受子組件的provide屬性值

具體的可以看官網介紹provide/inject:https://cn.vuejs.org/v2/api/#provide-inject

下面我們可以寫個簡單的例子來演示一下

父組件parent,我們在里面引入了一個子組件provideChild

<template>
  <div>
    <button @click="add">點擊增加</button>
    <provideChild/>
  </div>
</template>
<script>
import provideChild from '@/components/provideChild'
export default {
  components:{provideChild},
  data () {
    return {
      foo:5
    }
  },
  //依賴注入傳值
  provide(){
    return{
      newFoo:this.foo
    }
  },
  methods:{
    add(){
      this.foo ++
    },
  }
}
</script>
  

子組件provideChild,我們同時又在子組件里面引入了一個他的組件

我們可以看到他的打印出注入的newFoo值5

<template>
<section>
  <div>我是子組件:{{newFoo}}</div>
  <childChild/>
</section>
</template>
<script>
import childChild from '@/components/childChild'
export default {
  components:{
    childChild
  },
  inject:['newFoo'],
  mounted(){
    console.log(this.newFoo)
  },
  
}
</script>

孫子組件childChild

<template>
  <div>我是子組件的組件:{{newFoo}}</div>
</template>
<script>
export default {
  inject:['newFoo'],
}
</script>
  

接下來我們可以看一下頁面的

vue中父組件如何給子組件傳值

是可以展示的出來的,但是我們點擊增加的時候,子組件們都沒有響應,如果此時你有好好看文檔的話,就應該猜出為什么了

vue中父組件如何給子組件傳值

provide必須是個對象inject的綁定值才可以響應,那么我們可以試一試

//parent父組件的寫法
<template>
  <div>
    <button @click="add">點擊增加</button>
    <provideChild/>
  </div>
</template>
<script>
import provideChild from '@/components/provideChild'
export default {
  components:{provideChild},
  data () {
    return {
      fooObj:{
        foo:5
      }
    }
  },
  //依賴注入傳值
  provide(){
    return{
      newFoo:this.fooObj
    }
  },
  methods:{
    add(){
      this.fooObj.foo ++
    },
  }
}
</script>

//子組件provideChild
<template>
<section>
  <div>我是子組件:{{newFoo.foo}}</div>
  <childChild/>
</section>
</template>
<script>
import childChild from '@/components/childChild'
export default {
  components:{
    childChild
  },
  inject:['newFoo'],
  mounted(){
    console.log(this.newFoo)
  },
  
}
</script>

//孫子組件childChild
<template>
  <div>我是子組件的組件:{{newFoo.foo}}</div>
</template>
<script>
export default {
  inject:['newFoo'],
}
</script>

這樣我們就可以操作父組件的添加方法,得到子孫組件的響應

vue中父組件如何給子組件傳值

以上是“vue中父組件如何給子組件傳值”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

右玉县| 股票| 黑龙江省| 库伦旗| 洛川县| 柘城县| 特克斯县| 永吉县| 东港市| 永清县| 综艺| 拉萨市| 竹溪县| 休宁县| 衡水市| 凭祥市| 景德镇市| 突泉县| 禄丰县| 诸城市| 五常市| 利川市| 天柱县| 吴桥县| 吉林省| 湄潭县| 天等县| 越西县| 郁南县| 博罗县| 奉节县| 新安县| 潮州市| 胶州市| 寿宁县| 根河市| 华池县| 云阳县| 阿巴嘎旗| 泾源县| 丰顺县|