簡單易懂的React魔法(14):準(zhǔn)備開始編寫真正的項目

現(xiàn)在你可能會想知道教程的下一步是什么树肃,在這之前我們先總結(jié)一下現(xiàn)在你學(xué)到了什么:

  1. 如何安裝webpack茁肠,babel和react來用es6進行開發(fā)单寂。
  2. 如何創(chuàng)建基本react組件并引入app看靠。
  3. 如何寫JSX來渲染文本摔桦。
  4. 如何通過傳入props來給組件傳值端朵。
  5. 如何同時渲染多行文本好芭。
  6. 如何處理瀏覽器事件。
  7. 如何使用state冲呢,state和props的區(qū)別舍败。
  8. 如何通過循環(huán)渲染數(shù)組中的數(shù)據(jù)。

所有的這一切都會被用上:我們將會使用Ajax去獲取GitHub上的數(shù)據(jù)敬拓。好吧邻薯,技術(shù)上講我們要用的方法是Ajaj而不是Ajax。因為github提供的數(shù)據(jù)是JSON而不是XML乘凸,當(dāng)然這都不重要厕诡。如果你之前沒用過Ajax,這只是一種獲取遠程服務(wù)器數(shù)據(jù)的方法营勤。

在終端按ctrl+c退出webpack dev server然后運行下面的命令:

npm install --save superagent

SuperAgent是一個輕量級的Ajax工具灵嫌,它有簡單清晰的語法,易于學(xué)習(xí)使用葛作。我們現(xiàn)在要把之前的練手項目換成用Ajax調(diào)用GitHub API得到數(shù)據(jù)的項目寿羞,改動會有點大不過都是你見過的東西:

注意:當(dāng)superAgent安裝完,再重新打開webpack-dev-server赂蠢。
首先在constructor方法里找到這一行:

src/pages/Detail.js

const people = [];

for (let i = 0; i < 10; i++) {
    people.push({
        name: chance.first(),
        country: chance.country({ full: true })
    })
}

this.state = { people };

……然后刪掉他們绪穆。我們再也不需要這些了。順便也刪掉import Chance from 'chance'和整個buttonClicked()方法客年。別擔(dān)心霞幅,你學(xué)的這些都會用到漠吻,只是現(xiàn)在不需要了量瓜。

作為代替我們會創(chuàng)建一些很簡單的初始state:一個空數(shù)組。在Ajax完成后它會被填滿途乃。代碼如下:

src/pages/Detail.js

this.state = { commits: [] };

至于render()绍傲,我們要改變變量名不然他們只會輸出靜態(tài)數(shù)據(jù)。之后我們將填入細節(jié),很快的烫饼,現(xiàn)在先換成這樣:
src/pages/Detail.js

render() {
    return (<div>
    {this.state.commits.map((commit, index) => (
        <p key={index}>Some commit data here.</p>
    ))}
    </div>);
}

為了確保你跟著教程一步一步走猎塞,下面給出Detail.js:

src/pages/Detail.js

class Detail extends React.Component {
    constructor(props) {
        super(props);

        this.state = { commits: [] };
    }

    render() {
        return (<div>
        {this.state.commits.map((commit, index) => (
            <p key={index}>Some commit data here.</p>
        ))}
        </div>);
    }
}

一旦你保存文件,整個頁面會變空杠纵,因為commits數(shù)組是空的荠耽,下面我們來修改它。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末比藻,一起剝皮案震驚了整個濱河市铝量,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌银亲,老刑警劉巖慢叨,帶你破解...
    沈念sama閱讀 219,589評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異务蝠,居然都是意外死亡拍谐,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評論 3 396
  • 文/潘曉璐 我一進店門馏段,熙熙樓的掌柜王于貴愁眉苦臉地迎上來轩拨,“玉大人,你說我怎么就攤上這事毅弧∑蓿” “怎么了?”我有些...
    開封第一講書人閱讀 165,933評論 0 356
  • 文/不壞的土叔 我叫張陵够坐,是天一觀的道長寸宵。 經(jīng)常有香客問我,道長元咙,這世上最難降的妖魔是什么梯影? 我笑而不...
    開封第一講書人閱讀 58,976評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮庶香,結(jié)果婚禮上甲棍,老公的妹妹穿的比我還像新娘。我一直安慰自己赶掖,他們只是感情好感猛,可當(dāng)我...
    茶點故事閱讀 67,999評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著奢赂,像睡著了一般陪白。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上膳灶,一...
    開封第一講書人閱讀 51,775評論 1 307
  • 那天咱士,我揣著相機與錄音立由,去河邊找鬼。 笑死序厉,一個胖子當(dāng)著我的面吹牛锐膜,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播弛房,決...
    沈念sama閱讀 40,474評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼道盏,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了文捶?” 一聲冷哼從身側(cè)響起捞奕,我...
    開封第一講書人閱讀 39,359評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎拄轻,沒想到半個月后颅围,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,854評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡恨搓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,007評論 3 338
  • 正文 我和宋清朗相戀三年院促,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斧抱。...
    茶點故事閱讀 40,146評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡常拓,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出辉浦,到底是詐尸還是另有隱情弄抬,我是刑警寧澤,帶...
    沈念sama閱讀 35,826評論 5 346
  • 正文 年R本政府宣布宪郊,位于F島的核電站掂恕,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏弛槐。R本人自食惡果不足惜懊亡,卻給世界環(huán)境...
    茶點故事閱讀 41,484評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望乎串。 院中可真熱鬧店枣,春花似錦、人聲如沸叹誉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,029評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽长豁。三九已至钧唐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蕉斜,已是汗流浹背逾柿。 一陣腳步聲響...
    開封第一講書人閱讀 33,153評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留宅此,地道東北人机错。 一個月前我還...
    沈念sama閱讀 48,420評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像父腕,于是被迫代替她去往敵國和親弱匪。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,107評論 2 356

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