做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 21:58:36
文檔

Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)

Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間):前言 除了使用 Vuex 方法外,vue 提供了各種各樣的組件間通信的方案。文章整理一下父子組件、兄弟組件、祖先后代組件間是如何通信的。 💬 🌊 父子組件通信 props 和 $emit 父子組件通信 子組件有時(shí)需要與父組件進(jìn)行溝通,溝通的方式就是子組
推薦度:
導(dǎo)讀Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間):前言 除了使用 Vuex 方法外,vue 提供了各種各樣的組件間通信的方案。文章整理一下父子組件、兄弟組件、祖先后代組件間是如何通信的。 💬 🌊 父子組件通信 props 和 $emit 父子組件通信 子組件有時(shí)需要與父組件進(jìn)行溝通,溝通的方式就是子組

前言

除了使用 Vuex 方法外,vue 提供了各種各樣的組件間通信的方案。文章整理一下父子組件、兄弟組件、祖先后代組件間是如何通信的。 💬

🌊 父子組件通信

props 和 $emit 父子組件通信

子組件有時(shí)需要與父組件進(jìn)行溝通,溝通的方式就是子組件 emit 事件,父組件通過監(jiān)聽這個(gè)事件來做進(jìn)一步動(dòng)作。而父組件與子組件通信則使用 props

假設(shè)這里有一個(gè)父組件并引入了一個(gè)子組件 my-comp:

<my-comp v-for="msg in msgs" :key="msg.id" :msg="msg"></my-comp>

父組件有一系列 msg 數(shù)據(jù)需要通過子組件渲染,將 msg 作為 prop 傳遞給子組件即可:

import MyComp from '@/components/MyComp.vue'

export default {
 name: 'home',
 components: {
 MyComp
 },
 data () {
 return {
 msgs: [{
 id: 1, data: 'hello js'
 }, {
 id: 2, data: 'css world'
 }, {
 id: 3, data: 'animated style'
 }]
 }
 }
}

我們通過點(diǎn)擊子組件每一項(xiàng)觸發(fā)一個(gè)事件,父組件監(jiān)聽這個(gè)事件去動(dòng)態(tài)改變子組件的 color 樣式,這就是父組件監(jiān)聽子組件事件,事件處理函數(shù)可以從子組件傳遞值給父組件:

<my-comp v-for="msg in msgs" :key="msg.id" :msg="msg" :colored="colored" @handle-change-color="handleChangeColor"></my-comp>

首先增加一個(gè)事件 handle-change-color 當(dāng)這個(gè)事件被觸發(fā)時(shí)修改名為 color 的 data,然后將 colored 通過 props 傳入到子組件:

import MyComp from '@/components/MyComp.vue'

export default {
 name: 'home',
 components: { // 注冊(cè)組件
 MyComp
 },
 data () {
 return {
 colored: false, // 狀態(tài)
 msgs: [{
 id: 1, data: 'hello js'
 }, {
 id: 2, data: 'css world'
 }, {
 id: 3, data: 'animated style'
 }]
 }
 },
 methods: {
 handleChangeColor () {
 this.colored = !this.colored // 監(jiān)聽事件動(dòng)態(tài)改變 colored
 }
 // handleChangeColor (param) { // 子組件觸發(fā)的事件可能包含參數(shù)
 }
}

然后編輯子組件:

<div>
 <div @click="handleClick" :style="{color}">
 {{msg.id}} - {{msg.data}} ⭕
 </div>
</div>

首先渲染數(shù)據(jù),并監(jiān)聽 click 點(diǎn)擊事件,當(dāng)點(diǎn)擊觸發(fā)事件處理函數(shù) handleClick

export default {
 name: 'MyComp',
 computed: {
 color () { // color 為樣式
 return this.colored ? 'red' : 'black' // 根據(jù)父組件傳入的 props 動(dòng)態(tài)修改樣式
 }
 },
 props: ['msg', 'colored'],
 methods: {
 handleClick (e) {
 this.$emit('handle-change-color') // 使用 $emit 方法觸發(fā)父組件 handle-change-color 事件
 // this.$emit('handler', 'param') // 還可以給事件傳遞參數(shù)
 }
 }
}

子組件接收 colored 父組件傳遞來的 prop,返回一個(gè)計(jì)算后的屬性 color,根據(jù) colored 返回不同樣式。handleClick 處理當(dāng)子組件元素被點(diǎn)擊時(shí) $emit 派發(fā)父組件的 handle-change-color 事件

效果如下:

父組件 $children 操作子組件

使用 $children 操作子組件。如上述例子中,colored 被定義在父組件中,可以將其移動(dòng)到子組件中,并在父組件通過 $children 訪問到子組件:

<template>
 <div @click="handleClick" class="home">
 <my-comp v-for="msg in msgs" :key="msg.id" :msg="msg"></my-comp>
 </div>
</template>

handleClick 事件被放置在 div 中

import MyComp from '@/components/MyComp.vue'

export default {
 // ...
 data () {
 return {
 msgs: [{
 // ...
 }]
 }
 },
 methods: {
 handleClick () {
 this.$children.forEach(child => {
 child.$data.colored = !child.$data.colored // 逐一控制子組件的 $data
 })
 }
 }
}

在子組件中不需要 $emit 事件,只需維護(hù)一個(gè) data:

export default {
 name: 'MyComp',
 data () {
 return {
 colored: false // colored 狀態(tài)
 }
 },
 computed: {
 color () {
 return this.colored ? 'red' : 'black'
 }
 },
 props: ['msg']
}

子組件 $parent 訪問父組件

子組件可通過 $parent 來修改父組件的 $data,因此 colored 定義在父組件中。

<template>
 <div class="home">
 <my-comp v-for="msg in msgs" :key="msg.id" :msg="msg" :colored="colored"></my-comp>
 </div>
</template>

通過 prop 傳遞 colored 參數(shù)給子組件

import MyComp from '@/components/MyComp.vue'

export default {
 name: 'home',
 components: {
 MyComp
 },
 data () {
 return {
 colored: false, // 父組件維護(hù)一個(gè) colored 狀態(tài)
 msgs: [{
 // ...
 }]
 }
 }
}

父組件定義 colored 狀態(tài)

<template>
 <div>
 <div @click="handleClick" :style="{color}">
 {{msg.id}} - {{msg.data}} ⭕
 </div>
 </div>
</template>

子組件渲染 msg 并監(jiān)聽 click 事件

export default {
 // ...
 props: ['msg', 'colored'],
 methods: {
 handleClick (e) {
 this.$parent.$data.colored = !this.$parent.$data.colored
 }
 }
}

通過 $parent 訪問父組件,并修改 $data 狀態(tài)

非父子組件通信

中央事件總線

我們可以使用使用中央事件總線來處理非父子組件間的通信

具體步驟是創(chuàng)建一個(gè) Vue 實(shí)例,然后 $on 監(jiān)聽事件,$emit 來派發(fā)事件

// src/eventBus.js

import Vue from 'vue'
export default new Vue()

首先創(chuàng)建并導(dǎo)出一個(gè) Vue 實(shí)例

import bus from '@/eventbus'

export default {
 // ...
 methods: {
 handleClick (e) {
 bus.$emit('change-color')
 }
 }
}

后代元素 $emit 觸發(fā) eventBus 的事件

import bus from '@/eventbus'

export default {
 // ...
 mounted () {
 bus.$on('change-color', () => {
 this.colored = !this.colored
 })
 }
}

祖先元素 $on 方法監(jiān)聽 eventBus 的事件

provide/inject

適用于祖先和后代關(guān)系的組件間的通信,祖先元素通過 provide 提供一個(gè)值,后代元素則通過 inject 獲取到這個(gè)值。這個(gè)值默認(rèn)是非響應(yīng)的,如果是對(duì)象那么則是響應(yīng)式的:

export default {
 name: 'home',
 provide () {
 return {
 colored: this.colored // 依賴于 data
 }
 },
 components: {
 MyComp
 },
 data () {
 return {
 colored: { // 必須為對(duì)象
 value: false
 },
 msgs: [{
// ... 

首先通過 provide 對(duì)外提供一個(gè) colored,這個(gè)屬性依賴于 data 中的 colored,該變量必須為一個(gè)對(duì)象,才是響應(yīng)式的。

⚠️ 必須為一個(gè)對(duì)象

 methods: {
 handleChangeColor () {
 this.colored.value = !this.colored.value
 }
 }

祖先組件監(jiān)聽事件或其他途徑去修改 data 改變狀態(tài)。

export default {
 name: 'MyComp',
 inject: ['colored'], // inject colored
 computed: {
 color () {
 return this.colored.value ? 'red' : 'black' // do more...
 }
 },
// ...

后代組件通過 inject 獲取到祖先組件提供的對(duì)象,根據(jù)對(duì)象做進(jìn)一步動(dòng)作。

$root 直接訪問根組件

根據(jù)官方的文檔,我們可以通過 $root 來直接訪問到 Vue 實(shí)例

比方說將數(shù)據(jù)存儲(chǔ)在 Vue 實(shí)例中:

// src/main.js

new Vue({
 data () {
 return { // 在這里!!
 colored: false
 }
 },
 router,
 store,
 render: h => h(App)
}).$mount('#app')

然后我們?cè)谄渌鱾€(gè)組件中都能夠使用:

export default {
 name: 'MyComp',
 // ...
 mounted () {
 console.log(this.$root) // 直接訪問到根組件
 },
 // ...
}

總結(jié)

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)

Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間):前言 除了使用 Vuex 方法外,vue 提供了各種各樣的組件間通信的方案。文章整理一下父子組件、兄弟組件、祖先后代組件間是如何通信的。 💬 🌊 父子組件通信 props 和 $emit 父子組件通信 子組件有時(shí)需要與父組件進(jìn)行溝通,溝通的方式就是子組
推薦度:
標(biāo)簽: VUE 通信 祖先
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 吴忠市| 玉林市| 嘉峪关市| 云南省| 怀安县| 深州市| 观塘区| 临漳县| 常山县| 即墨市| 当阳市| 枣庄市| 南京市| 肇东市| 五大连池市| 历史| 新巴尔虎右旗| 临沧市| 吴旗县| 金秀| 阳谷县| 潮州市| 许昌市| 虞城县| 翁源县| 舞阳县| 容城县| 格尔木市| 腾冲县| 奉节县| 金塔县| 岳阳市| 容城县| 江陵县| 图木舒克市| 延川县| 阳江市| 维西| 隆回县| 基隆市| 新安县|