vuejs如何設定父子通訊
vuejs設定父子通訊的方法:1、父元件利用props向子元件傳遞資料;2、子元件透過“$emit”給父元件傳送訊息;3、利用“.sync”語法糖;4、利用“$attrs”和“$listeners”;5、利用privide和inject。
本教程操作環境:windows7系統、vue2.9.6版,DELL G3電腦。
Vue 父子元件之間的通訊有一下幾種方式:
props
$emit -- 元件封裝用的比較多
.sync -- 語法糖
$attrs 和 $listeners -- 元件封裝用的比較多
privide 和 inject -- 高階元件
下面將分別介紹
1、 props
這個在日常開發中運用較多,簡單來說,我們可以透過props向子元件傳遞資料,就像一個水管一樣,父元件的資料從上往下流向子元件,不能逆流。這也是vue的設計概論之單項資料流。
<div id="app"> <child :content="message"></child> </div> // Js let Child = Vue.extend({ template: '<h2>{{ content }}</h2>', props: { content: { type: String, default: () => { return 'from child' } } } }) new Vue({ el: '#app', data: { message: 'from parent' }, components: { Child } })
2、$emit
官方介紹是觸發當前例項上得事件,附加引數都會傳給監聽器回撥。
<div id="app"> <my-button @greet="sayHi"></my-button> </div> let MyButton = Vue.extend({ template: '<button @click="triggerClick">click</button>', 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的時候,曾作為雙向繫結功能存在,即子元件可以修改父元件中的值。因為它違反了單向資料流的設計理念,所以在vue2.x中被去掉了,但是在vue 2.3.0+以上的版本中又從新引入了這個 .sync 修飾符。但是隻作為一個編譯時的語法糖存在。它被擴充套件為一個自動更新父元件屬性的 v-on 監聽器。
在有些情況下,我們可能需要對一個 prop 進行“雙向繫結”。不幸的是,真正的雙向繫結會帶來維護上的問題,因為子元件可以修改父元件,且在父元件和子元件都沒有明顯的改動來源。
語法糖的寫法形式如下
<text-document v-bind:title="doc.title" v-on:update:title="doc.title = $event"> </text-document>
於是我們可以用.sync 語法糖簡寫成如下形式
<text-document v-bind:title.sync="doc.title"></text-document>
那麼如何做到雙向繫結呢,例如改變子元件文字框中的值同時改變父元件中的值,程式碼如下
<div id="app"> <login :name.sync="userName"></login> {{ userName }} </div> let Login = Vue.extend({ template: ` <div class="input-group"> <label>姓名:</label> <input v-model="text"> </div> `, 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
官網對 $attrs 的解釋如下:
包含了父作用域中不作為 prop 被識別 (且獲取) 的特性繫結 (class 和 style 除外)。當一個元件沒有宣告任何 prop 時,這裡會包含所有父作用域的繫結 (class 和 style 除外),並且可以透過 v-bind="$attrs" 傳入內部元件——在建立高階別的元件時非常有用。
官網對 $listeners 的解釋如下:
包含了父作用域中的 (不含 .native 修飾器的) v-on 事件監聽器。它可以透過 v-on="$listeners" 傳入內部元件——在建立更高層次的元件時非常有用。
$attrs 和 $listeners 屬性像兩個收納箱,一個負責收納屬性,一個負責收納事件,都是以物件的形式來儲存資料
<div id="app"> <child :foo="foo" :bar="bar" @one.native="triggerOne" @two="triggerTwo"> </child> </div>
let Child = Vue.extend({ template: '<h2>{{ foo }}</h2>', 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 進行資料傳遞,在需要的地方進行呼叫和處理,還是很方便的。當然,我們還可以透過 v-on="$listeners" 一級級的往下傳遞,子子孫孫無窮盡也!
5、privide 和 inject
來看下官方對 provide / inject 的描述:
provide 和 inject 主要為高階外掛/元件庫提供用例。並不推薦直接用於應用程式程式碼中。並且這對選項需要一起使用,以允許一個祖先元件向其所有子孫後代注入一個依賴,不論元件層次有多深,並在起上下游關係成立的時間裡始終生效。
<div id="app"> <son></son> </div> let Son = Vue.extend({ template: '<h2>son</h2>', 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 } })
更多列子可以參考element-ui原始碼,其中的大量使用了該方法
相關推薦:《》
以上就是vuejs如何設定父子通訊的詳細內容,更多請關注php中文網其它相關文章!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/1817/viewspace-2827173/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- vue 父子元件通訊Vue元件
- Vue 父子元件的通訊Vue元件
- 父子元件之間通訊元件
- react父子、子父、兄弟通訊React
- 我學react之父子元件通訊React元件
- vue父子元件通訊高階用法Vue元件
- Vue2.0父子元件間通訊Vue元件
- Vue父子元件通訊小總結Vue元件
- vue--select父子元件通訊Vue元件
- Vue中父子元件通訊——元件todolistVue元件
- vue 2 0 元件:父子元件通訊Vue元件
- iframe父子頁面通訊解決方案
- prop父子元件通訊,動靜態prop元件
- 會vue,學習react元件父子通訊VueReact元件
- vue2.0父子、兄弟元件通訊,$emit使用Vue元件MIT
- 3.Vue非父子元件之間的通訊Vue元件
- Vue之父子、同級元件的通訊詳解Vue元件
- 關於React父子元件通訊知識總結React元件
- 父子頁面之間跨域通訊的方法跨域
- 華為通訊裝置密碼設定密碼
- Vue.js 父子元件通訊的1212種方式Vue.js元件
- Vue父子組建的簡單通訊之控制開關SwitchVue
- 最近在看父子元件通訊中遇到的一個問題?元件
- vue: 從一個下拉框元件理解vue中的父子通訊Vue元件
- vue之父子元件間通訊例項講解(props、$ref、$emit)Vue元件MIT
- vue2.0 非父子元件之間的單一事件通訊Vue元件事件
- vue 自定義元件 v-model雙向繫結、 父子元件同步通訊Vue元件
- 總結Vue第二天:自定義子元件、父子元件通訊、插槽Vue元件
- 父子元件通訊——模擬12306購票新增乘車人元件
- vuejs 免費視訊課程VueJS
- JavaScript 釋出-訂閱設計模式實現 React EventBus(相當於vue的$Bus)非父子之間通訊JavaScript設計模式ReactVue
- Angular父子元件通過服務傳參Angular元件
- 樂訊通雲通訊:如何選擇物聯網路卡
- 如何設計一個好的通訊網路協議協議
- 如何在Mac上設定自定義鎖屏訊息?Mac
- 如何給FineReport設定自定義訊息提醒工具
- 天邑通訊HASB-100的PPPOE自動撥號設定(黑色波浪型) 詳細設定!
- 如何優雅的實現訊息通訊?