pubsub-js 在react中組件之間通信敦姻,消息訂閱發(fā)布實(shí)現(xiàn)

app.jsx

import React, { Component } from 'react'
import Search from './components/Search'
import List from './components/List'

export default class App extends Component {
    render() {
        return (
            <div className="container">
                <Search/>
                <List/>
            </div>
        )
    }
}

Search組件

import React, { Component } from 'react'
import PubSub from 'pubsub-js'
import axios from 'axios'

export default class Search extends Component {

    search = ()=>{
        //獲取用戶的輸入(連續(xù)解構(gòu)賦值+重命名)
        const {keyWordElement:{value:keyWord}} = this
        //發(fā)送請(qǐng)求前通知List更新?tīng)顟B(tài)
        PubSub.publish('atguigu',{isFirst:false,isLoading:true})
        //發(fā)送網(wǎng)絡(luò)請(qǐng)求
        axios.get(`/api1/search/users?q=${keyWord}`).then(
            response => {
                //請(qǐng)求成功后通知List更新?tīng)顟B(tài)
                PubSub.publish('atguigu',{isLoading:false,users:response.data.items})
            },
            error => {
                //請(qǐng)求失敗后通知App更新?tīng)顟B(tài)
                PubSub.publish('atguigu',{isLoading:false,err:error.message})
            }
        )
    }

    render() {
        return (
            <section className="jumbotron">
                <h3 className="jumbotron-heading">搜索github用戶</h3>
                <div>
                    <input ref={c => this.keyWordElement = c} type="text" placeholder="輸入關(guān)鍵詞點(diǎn)擊搜索"/>&nbsp;
                    <button onClick={this.search}>搜索</button>
                </div>
            </section>
        )
    }
}

List組件

import React, { Component } from 'react'
import PubSub from 'pubsub-js'
import './index.css'

export default class List extends Component {

    state = { //初始化狀態(tài)
        users:[], //users初始值為數(shù)組
        isFirst:true, //是否為第一次打開(kāi)頁(yè)面
        isLoading:false,//標(biāo)識(shí)是否處于加載中
        err:'',//存儲(chǔ)請(qǐng)求相關(guān)的錯(cuò)誤信息
    } 

    componentDidMount(){
        this.token = PubSub.subscribe('atguigu',(_,stateObj)=>{
            this.setState(stateObj)
        })
    }

    componentWillUnmount(){
        PubSub.unsubscribe(this.token)
    }

    render() {
        const {users,isFirst,isLoading,err} = this.state
        return (
            <div className="row">
                {
                    isFirst ? <h2>歡迎使用二庵,輸入關(guān)鍵字钳幅,隨后點(diǎn)擊搜索</h2> :
                    isLoading ? <h2>Loading......</h2> :
                    err ? <h2 style={{color:'red'}}>{err}</h2> :
                    users.map((userObj)=>{
                        return (
                            <div key={userObj.id} className="card">
                                <a rel="noreferrer" href={userObj.html_url} target="_blank">
                                    <img alt="head_portrait" src={userObj.avatar_url} style={{width:'100px'}}/>
                                </a>
                                <p className="card-text">{userObj.login}</p>
                            </div>
                        )
                    })
                }
            </div>
        )
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末秉剑,一起剝皮案震驚了整個(gè)濱河市蜜氨,隨后出現(xiàn)的幾起案子械筛,更是在濱河造成了極大的恐慌,老刑警劉巖飒炎,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件埋哟,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡郎汪,警方通過(guò)查閱死者的電腦和手機(jī)赤赊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)煞赢,“玉大人抛计,你說(shuō)我怎么就攤上這事≌罩” “怎么了吹截?”我有些...
    開(kāi)封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)凝危。 經(jīng)常有香客問(wèn)我波俄,道長(zhǎng),這世上最難降的妖魔是什么蛾默? 我笑而不...
    開(kāi)封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任懦铺,我火速辦了婚禮,結(jié)果婚禮上支鸡,老公的妹妹穿的比我還像新娘冬念。我一直安慰自己,他們只是感情好牧挣,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布刘急。 她就那樣靜靜地躺著,像睡著了一般浸踩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上统求,一...
    開(kāi)封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天检碗,我揣著相機(jī)與錄音据块,去河邊找鬼。 笑死折剃,一個(gè)胖子當(dāng)著我的面吹牛另假,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播怕犁,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼边篮,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了奏甫?” 一聲冷哼從身側(cè)響起戈轿,我...
    開(kāi)封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎阵子,沒(méi)想到半個(gè)月后思杯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡挠进,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年色乾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片领突。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡暖璧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出君旦,到底是詐尸還是另有隱情澎办,我是刑警寧澤,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布于宙,位于F島的核電站浮驳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏捞魁。R本人自食惡果不足惜至会,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望谱俭。 院中可真熱鬧奉件,春花似錦、人聲如沸昆著。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)凑懂。三九已至煤痕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背摆碉。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工塘匣, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人巷帝。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓忌卤,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親楞泼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子驰徊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

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

  • 需要組件之進(jìn)行通信的幾種情況 父組件向子組件通信 子組件向父組件通信 跨級(jí)組件通信 沒(méi)有嵌套關(guān)系組件之間的通信 1...
    lovelydong閱讀 201評(píng)論 0 0
  • 最近在整理了一下長(zhǎng)滿灰的塵印象筆記,發(fā)現(xiàn)之前摘錄的一篇文章:) React 是以組合組件的形式組織的堕阔,組件因?yàn)楸舜?..
    cobbyzhao閱讀 2,104評(píng)論 0 0
  • 需要組件之進(jìn)行通信的幾種情況: 父組件向子組件通信 子組件向父組件通信 跨級(jí)組件通信 沒(méi)有嵌套關(guān)系組件之間的通信 ...
    Sun____閱讀 408評(píng)論 0 0
  • 語(yǔ)法規(guī)則: ## JSX的由來(lái) React為了方便View層組件化棍厂。承載了構(gòu)建HTML結(jié)構(gòu)化頁(yè)面的職責(zé)。從這點(diǎn)上來(lái)...
    考拉_2044閱讀 314評(píng)論 0 0
  • 本文介紹 本文主要講解JavaScript中的發(fā)布-訂閱模式印蔬,也可以叫做觀察者模式勋桶,個(gè)人覺(jué)得前者叫法更適合從代碼的...
    不洗頭的野人閱讀 2,183評(píng)論 1 3