真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

vuejs怎么設置父子通信

這篇文章主要介紹了vuejs怎么設置父子通信,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)公司是一家從事企業(yè)網(wǎng)站建設、成都網(wǎng)站建設、網(wǎng)站建設、行業(yè)門戶網(wǎng)站建設、網(wǎng)頁設計制作的專業(yè)網(wǎng)站建設公司,擁有經(jīng)驗豐富的網(wǎng)站建設工程師和網(wǎng)頁設計人員,具備各種規(guī)模與類型網(wǎng)站建設的實力,在網(wǎng)站建設領域樹立了自己獨特的設計風格。自公司成立以來曾獨立設計制作的站點近1000家。

vuejs設置父子通信的方法:1、父組件利用props向子組件傳遞數(shù)據(jù);2、子組件通過“$emit”給父組件發(fā)送消息;3、利用“.sync”語法糖;4、利用“$attrs”和“$listeners”;5、利用privide和inject。

本教程操作環(huán)境:windows7系統(tǒng)、vue2.9.6版,DELL G3電腦。

Vue 父子組件之間的通信有一下幾種方式:

  • props

  • $emit -- 組件封裝用的比較多

  • .sync -- 語法糖

  • $attrs 和 $listeners -- 組件封裝用的比較多

  • privide 和 inject -- 高階組件

下面將分別介紹

1、 props

這個在日常開發(fā)中運用較多,簡單來說,我們可以通過props向子組件傳遞數(shù)據(jù),就像一個水管一樣,父組件的數(shù)據(jù)從上往下流向子組件,不能逆流。這也是vue的設計概論之單項數(shù)據(jù)流。


  
// Js let Child = Vue.extend({   template: '

{{ content }}

',   props: {     content: {       type: String,       default: () => { return 'from child' }     }   } }) new Vue({   el: '#app',   data: {     message: 'from parent'   },   components: {     Child   } })

2、$emit

官方介紹是觸發(fā)當前實例上得事件,附加參數(shù)都會傳給監(jiān)聽器回調。


  
let MyButton = Vue.extend({   template: 'click',   data () {     return {       greeting: 'vue.js!'     }   },   methods: {     triggerClick () {       this.$emit('greet', this.greeting)     }   } }) new Vue({   el: '#app',   components: {     MyButton   },   methods: {     sayHi (val) {       alert('Hi, ' + val) // 'Hi, vue.js!'     }   } })

3、.sync 修飾符

在vue1.x的時候,曾作為雙向綁定功能存在,即子組件可以修改父組件中的值。因為它違反了單向數(shù)據(jù)流的設計理念,所以在vue2.x中被去掉了,但是在vue 2.3.0+以上的版本中又從新引入了這個 .sync 修飾符。但是只作為一個編譯時的語法糖存在。它被擴展為一個自動更新父組件屬性的 v-on 監(jiān)聽器。

在有些情況下,我們可能需要對一個 prop 進行“雙向綁定”。不幸的是,真正的雙向綁定會帶來維護上的問題,因為子組件可以修改父組件,且在父組件和子組件都沒有明顯的改動來源。

語法糖的寫法形式如下


于是我們可以用.sync 語法糖簡寫成如下形式

那么如何做到雙向綁定呢,例如改變子組件文本框中的值同時改變父組件中的值,代碼如下


   {{ userName }}
let Login = Vue.extend({   template: `                           `,   props: ['name'],   data () {     return {       text: ''     }   },   watch: {     text (newVal) {       this.$emit('update:name', newVal)     }   } }) new Vue({   el: '#app',   data: {     userName: ''   },   components: {     Login   } })

代碼里只有一句話:

this.$emit('update:name', newVal)

官方語法是:update:myPropName 其中 myPropName 表示要更新的 prop 值。當然如果你不用 .sync 語法糖使用上面的 .$emit 也能達到同樣的效果

4、 $attrs 和 $listeners

官網(wǎng)對 $attrs 的解釋如下:

包含了父作用域中不作為 prop 被識別 (且獲取) 的特性綁定 (class 和 style 除外)。當一個組件沒有聲明任何 prop 時,這里會包含所有父作用域的綁定 (class 和 style 除外),并且可以通過 v-bind="$attrs" 傳入內部組件——在創(chuàng)建高級別的組件時非常有用。

官網(wǎng)對 $listeners 的解釋如下:

包含了父作用域中的 (不含 .native 修飾器的) v-on 事件監(jiān)聽器。它可以通過 v-on="$listeners" 傳入內部組件——在創(chuàng)建更高層次的組件時非常有用。

$attrs 和 $listeners 屬性像兩個收納箱,一個負責收納屬性,一個負責收納事件,都是以對象的形式來保存數(shù)據(jù)


  
  
let Child = Vue.extend({
  template: '

{{ foo }}

',   props: ['foo'],   created () {     console.log(this.$attrs, this.$listeners)     // -> {bar: "parent bar"}     // -> {two: fn}     // 這里我們訪問父組件中的 `triggerTwo` 方法     this.$listeners.two()     // -> 'two'   } }) new Vue({   el: '#app',   data: {     foo: 'parent foo',     bar: 'parent bar'   },   components: {     Child   },   methods: {     triggerOne () {       alert('one')     },     triggerTwo () {       alert('two')     }   } })

可以看到,我們可以通過 $attrs 和 $listeners 進行數(shù)據(jù)傳遞,在需要的地方進行調用和處理,還是很方便的。當然,我們還可以通過 v-on="$listeners" 一級級的往下傳遞,子子孫孫無窮盡也!

5、privide 和 inject

來看下官方對 provide / inject 的描述:

provide 和 inject 主要為高階插件/組件庫提供用例。并不推薦直接用于應用程序代碼中。并且這對選項需要一起使用,以允許一個祖先組件向其所有子孫后代注入一個依賴,不論組件層次有多深,并在起上下游關系成立的時間里始終生效。



  



let Son = Vue.extend({
  template: '

son

',   inject: {     house: {       default: '沒房'     },     car: {       default: '沒車'     },     money: {       // 長大工作了雖然有點錢       // 僅供生活費,需要向父母要       default: '¥4500'     }   },   created () {     console.log(this.house, this.car, this.money)     // -> '房子', '車子', '¥10000'   } }) new Vue({   el: '#app',   provide: {     house: '房子',     car: '車子',     money: '¥10000'   },   components: {     Son   } })

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vuejs怎么設置父子通信”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!


名稱欄目:vuejs怎么設置父子通信
URL網(wǎng)址:http://weahome.cn/article/giesee.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部