三大前端框架(react、vue纷纫、angular2+)父子組件通信總結(jié)

前言

公司業(yè)務(wù)需要枕扫,react、vue辱魁、angular都有接觸[\無奈臉]烟瞧。雖然說可以拓展知識廣度,但是在深度上很讓人頭疼染簇。最近沒事的時候回憶各框架父子組件通信参滴,發(fā)現(xiàn)很模糊,于是乎稍微做了一下功課锻弓,記錄于此砾赔,以便加深理解。

React

React是單向數(shù)據(jù)流青灼,當(dāng)有多個組件需要共享狀態(tài)的時候暴心,這就需要把狀態(tài)放到這些組件共有的父組件中,相應(yīng)地杂拨,這些組件就變成了子組件专普,從而涉及到父子組件之間的通信。
  父組件通過props 給子組件傳遞數(shù)據(jù)弹沽,子組件則是通過調(diào)用父組件傳給它的函數(shù)給父組件傳遞數(shù)據(jù)檀夹。
父組件:

import React, { Component } from 'react';
import Child from './child'
 
class App extends Component {
    constructor(props){
        super(props);
        this.state={
            msg:'父類的消息',
            name:'John',
            age:50
        };
       this.callback = this.callback.bind(this);
    }
   // 通過子組件調(diào)用該方法接收從子組件傳過來的消息
    callback(msg,name,age){
        this.setState({msg});
        this.setState({name});
        this.setState({age});
    }
 
  render() {
    return (
      <div className="App">
        <p> Message: &nbsp;&nbsp;{this.state.msg}</p>
        <Child callback={this.callback} age={this.state.age} name={this.state.name}>    
        </Child>
      </div>
    );
  }
}
 
export default App;

子組件:

import React from "react";
 
class Child extends React.Component{
    constructor(props){
        super(props);
        this.state={
            name:'Andy',
            age:20,
            msg:"來自子類的消息"
        };
        // 這里目的是為了改變this的指向筋粗。使得在函數(shù)單獨調(diào)用的時候,函數(shù)內(nèi)部的this依然指向child組件击胜,亦可用箭頭函數(shù)的方式
        this.change = this.change.bind(this);
    }
 
    change(){
        //調(diào)用父組件的方法修改父組件的內(nèi)容,即子傳父
     this.props.callback(this.state.msg,this.state.name,this.state.age);
    }
   // 通過this.props接收從父組件穿過來的消息
    render(){
        return(
            <div>    
                <div>{this.props.name}</div>
                <div>{this.props.age}</div>
                <button onClick={this.change}>點擊</button>
            </div>
        )
    }
}
 
export default Child;

VUE

1.父—>子

<!-- 父組件 -->
// 父組件通過屬性綁定給子組件傳值
<parent>
    <child :parentToChild="content"></child> 
</parent>

data(){
    return {
        content:'sichaoyun'
    };
}

<!-- 子組件 -->
// 子組件通過props接收數(shù)據(jù)
export default {
    props: {
        parentToChild: String        // 指定字符串類型亏狰,這里還有其他方式,可參考下面鏈接
    } 
}

//子組件接收后就可以在template中使用
// 或者在方法中通過this.parentToChild使用
<template>
  <div>
    <p>{{parentToChild}}</p>
  </div>
</template>
  1. 子—>父
//vue2.0只允許單向數(shù)據(jù)傳遞偶摔,我們通過出發(fā)事件來改變組件的數(shù)據(jù)

<!-- 子組件代碼 -->
<template>
    <div @click="open"></div>
</template>

methods: {
   open() {
        this.$emit('showbox','the msg'); //觸發(fā)showbox方法暇唾,'the msg'為向父組件傳遞的數(shù)據(jù)
    }
}

<!-- 父組件代碼 -->
<child @showbox="toshow"></child> //監(jiān)聽子組件觸發(fā)的showbox事件,然后調(diào)用toshow方法

methods: {
    toshow(value) {
        console.log(value);   // the msg
    }
}
  1. 補充以下用emit和on來進行父子以及兄弟組件通信的知識,雙手奉上鏈接
    兄弟組件通信問題:emit和on

Angular2+

  1. 父—>子
// -----------------------------父組件---------------------------
// js:在裝飾器下面的類里寫的數(shù)據(jù)辰斋。
export class Father{    
    msg="來自父組件的問候"
}
// html:  通過屬性綁定傳值
<app-child [msg]="msg"></app-child> //放在子組件的屬性上


// ----------------------------------子組件---------------------------
// js:引入Input模塊
    export class child{
        @Input() msg; //子組件得到數(shù)據(jù)
    }
// html:
<p>{{msg}}</p> //子組件進行頁面渲染
  1. 子—>父
    子組件使用EventEmitter創(chuàng)建自定義事件策州,并且通過@Output()裝飾器把它作為屬性暴露出來,父組件通過綁定這個屬性來監(jiān)聽事件從而獲取子組件數(shù)據(jù)宫仗。
// 使用emit自定義事件
// ------------------- 子組件代碼-----------------------------------------
   //  ts:導(dǎo)入Output和EventEmitter兩個模塊
        export class Child{
            @Output() constmEventToApp=new EventEmitter();//創(chuàng)建emit事件
            ngInit(){
                this.constmEventToApp.emit("數(shù)據(jù)") //在dom掛載時將數(shù)據(jù)放入自定義事件中
            }
        }

// -----------------------------父組件代碼------------------------------
    // html:
    <Child (constmEventToApp)="handleData($event)"></Child>//將子組件中的自定義事件綁定到父組件下面的子組件標簽上够挂。
   //  ts:
    export class Father{
        handleDate(ev){
            console.log(ev);//ev就是子組件所傳遞過來的數(shù)據(jù)
        }
    }

總結(jié)至此!由于本人才疏學(xué)淺藕夫,各處借鑒得此文章孽糖,so卿啡,有不對的地方歡迎各路大神指正脯倒,非常感謝!

特別鳴謝下面各位大神的文章牙甫,附上鏈接于此
React 父子組件之間的通信
vue2.0 父子組件通信 兄弟組件通信
angular,vue,react的父子通信

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末滩褥,一起剝皮案震驚了整個濱河市病蛉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌瑰煎,老刑警劉巖铺然,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異酒甸,居然都是意外死亡魄健,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門插勤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诀艰,“玉大人,你說我怎么就攤上這事饮六。” “怎么了苛蒲?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵卤橄,是天一觀的道長。 經(jīng)常有香客問我臂外,道長窟扑,這世上最難降的妖魔是什么喇颁? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮嚎货,結(jié)果婚禮上橘霎,老公的妹妹穿的比我還像新娘。我一直安慰自己殖属,他們只是感情好姐叁,可當(dāng)我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著洗显,像睡著了一般外潜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上挠唆,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天处窥,我揣著相機與錄音,去河邊找鬼玄组。 笑死滔驾,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的俄讹。 我是一名探鬼主播哆致,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼颅悉!你這毒婦竟也來了沽瞭?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤剩瓶,失蹤者是張志新(化名)和其女友劉穎驹溃,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體延曙,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡豌鹤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了枝缔。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片布疙。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖愿卸,靈堂內(nèi)的尸體忽然破棺而出灵临,到底是詐尸還是另有隱情,我是刑警寧澤趴荸,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布儒溉,位于F島的核電站,受9級特大地震影響发钝,放射性物質(zhì)發(fā)生泄漏顿涣。R本人自食惡果不足惜波闹,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望涛碑。 院中可真熱鬧精堕,春花似錦、人聲如沸蒲障。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽晌涕。三九已至滋捶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間余黎,已是汗流浹背重窟。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留惧财,地道東北人巡扇。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像垮衷,于是被迫代替她去往敵國和親厅翔。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容