全棧React: 第3天 我們的第一個組件

全棧React: 第3天 我們的第一個組件

本文轉載自:眾成翻譯
譯者:iOSDevLog
鏈接:http://www.zcfy.cc/article/3799
原文:https://www.fullstackreact.com/30-days-of-react/day-3/

這個系列的前兩篇文章是很重要的討論蓬戚。在今天的課程中,我們來看看一些代碼呵曹,并寫下我們的第一個React應用十气。

讓我們重溫第一天介紹的Hello world應用雅倒。這次拷邢,略有不同:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Hello world</title>
  <!-- Script tags including React -->
  ``<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.3.1/react.min.js">``</script>
  ``<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.3.1/react-dom.min.js">``</script>
  ``<script src="https://npmcdn.com/babel-core@5.8.38/browser.min.js">`` </script>
</head>
<body>
  <div id="app"></div>
  ``<script type="text/babel">``
    var app = <h1>Hello world</h1>
    var mountComponent = document.querySelector('#app');
    ReactDOM.render(app, mountComponent);
  </script>
</body>
</html>

加載React庫

我們在包含了React的來源作為<script>`標簽在`<head>元素里面香府。在我們開始編寫我們的React應用之前放置我們的<script>加載標簽很重要允趟,以便我們使用ReactReactDOM恼策。

head還有一個script標簽包括在一個babel-core庫。但是什么babel-core潮剪?

Babel

昨天我們談了ES5和ES6涣楷。我們提到對ES6的支持仍然不穩(wěn)定。為了使用ES6抗碰,最好是將ES6 JavaScript轉換為ES5 JavaScript狮斗。

Babel是一個將ES6轉換到ES5的庫。

body里面我們有一個script弧蝇。在script里我們定義了我們的第一個React應用碳褒。請注意,script標簽具有typetext/babel

`<script type="text/babel">`

這告訴Babel看疗,我們希望它處理這個script主體內的JavaScript的執(zhí)行沙峻。我們可以使用ES6 JavaScript編寫我們的React應用,并確保Babel將在僅支持ES5的瀏覽器中處理它的執(zhí)行两芳。

### React應用

在Babel script中摔寨,我們定義了我們的第一個React應用尤蛮。我們的應用由一個單一的元素組成<h1>Hello world</h1>挑辆。調用ReactDOM.render()實際上將我們的袖珍React應用放置在頁面上。如果不調用ReactDOM.render()咬清,DOM中不會呈現(xiàn)任何內容竖螃。ReactDOM.render()的第一個參數是呈現(xiàn) 什么淑廊,第二個是 哪里

`ReactDOM.render(<what>, <where>)`

我們寫了一個React應用。我們的“app”是一個代表一個h1 標簽的React元素斑鼻。但這不是很有趣蒋纬。富Web應用接受用戶輸入,根據用戶交互更改其形狀坚弱,并與Web服務器通信蜀备。讓我們通過構建我們的第一個React組件來開始接觸這個力量。

組件和更多

我們在本系列的開頭提到荒叶,所有React應用的核心是組件碾阁。理解React組件的最好方法是編寫它們。我們將把React組件寫成ES6類些楣。

Let's look at a component we'll call App. Like all other React components, this ES6 class will extend the React.Component class from the React package:
讓我們來看一個我們要調用的組件App脂凶。像所有其他React組件一樣宪睹,這個ES6類將擴展(繼承)React包中的React.Component 類:

class App extends React.Component {
  render() {
    return <h1>Hello from our app</h1>
  }
}

所有React組件至少需要一個render() 函數。此render() 函數應返回瀏覽器DOM元素的虛擬DOM表示形式蚕钦。

有多種方法來編寫React組件亭病。在本系列中,我們將介紹幾種編寫方法嘶居。我們將使用的最常見的形式是上面使用的ES6類表示罪帖。

另一種編寫我們的App 組件的方式是使用該React.createClass()函數。

> var App = React.createClass({
>   render: function() {
>     return <h1>Hello from our app</h1>
>   }
> }); 
>

到目前為止邮屁,社區(qū)一直采用ES6類聲明整袁。但是這兩種方法都產生具有相同特性的React組件。

在我們的index.html佑吝,我們用之前的新App 組件替換我們的JavaScript坐昙。

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Hello world</title>
  <!-- Script tags including React -->
  ``<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.3.1/react.min.js">``</script>
  ``<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.3.1/react-dom.min.js">``</script>
  ``<script src="https://npmcdn.com/babel-core@5.8.38/browser.min.js">``</script>
</head>
<body>
  <div id="app"></div>
  ``<script type="text/babel">``
    class App extends React.Component {
      render() {
        return <h1>Hello from our app</h1>
      }
    }
  </script>
</body>
</html>

然而,什么都不會在屏幕上呈現(xiàn)芋忿。你還記得為什么嗎炸客?

我們沒有告訴React我們要在屏幕上渲染任何東西,或者在什么地方渲染它盗飒。我們需要再次使用ReactDOM.render() 函數來表達React我們想要呈現(xiàn)的內容和位置嚷量。

添加ReactDOM.render() 函數將在屏幕上呈現(xiàn)我們的應用:

var mount = document.querySelector('#app');
ReactDOM.render(<App />, mount);

請注意,我們可以使用App類來渲染我們的React應用逆趣,就像它是一個內置的DOM組件類型(像<h1 /><div />標簽一樣)蝶溶。這里我們使用它,就像它是一個帶尖括號的元素:<App />宣渗。

我們的React組件的行為就像我們頁面上的任何其他元素一樣抖所,我們可以像構建一個本地瀏覽器樹一樣構建一個組件樹。

雖然我們現(xiàn)在渲染一個React組件痕囱,我們的應用仍然缺乏豐富性或交互性田轧。很快,我們將看到如何使React組件數據驅動和動態(tài)鞍恢。但首先傻粘,在本系列的下一期中,我們將探討如何對圖層組件進行分層帮掉。嵌套組件是豐富的React Web應用的基礎弦悉。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蟆炊,隨后出現(xiàn)的幾起案子稽莉,更是在濱河造成了極大的恐慌,老刑警劉巖涩搓,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件污秆,死亡現(xiàn)場離奇詭異劈猪,居然都是意外死亡,警方通過查閱死者的電腦和手機良拼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進店門战得,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人将饺,你說我怎么就攤上這事贡避⊥蠢瑁” “怎么了予弧?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長湖饱。 經常有香客問我掖蛤,道長,這世上最難降的妖魔是什么井厌? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任蚓庭,我火速辦了婚禮,結果婚禮上仅仆,老公的妹妹穿的比我還像新娘器赞。我一直安慰自己,他們只是感情好墓拜,可當我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布港柜。 她就那樣靜靜地躺著,像睡著了一般咳榜。 火紅的嫁衣襯著肌膚如雪夏醉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天涌韩,我揣著相機與錄音畔柔,去河邊找鬼。 笑死臣樱,一個胖子當著我的面吹牛靶擦,可吹牛的內容都是我干的。 我是一名探鬼主播雇毫,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼玄捕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了嘴拢?” 一聲冷哼從身側響起桩盲,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎席吴,沒想到半個月后赌结,有當地人在樹林里發(fā)現(xiàn)了一具尸體捞蛋,經...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年柬姚,在試婚紗的時候發(fā)現(xiàn)自己被綠了拟杉。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡量承,死狀恐怖搬设,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情撕捍,我是刑警寧澤拿穴,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站忧风,受9級特大地震影響默色,放射性物質發(fā)生泄漏。R本人自食惡果不足惜狮腿,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一腿宰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧缘厢,春花似錦吃度、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至夜畴,卻和暖如春拖刃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背贪绘。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工兑牡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人税灌。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓均函,卻偏偏與公主長得像,于是被迫代替她去往敵國和親菱涤。 傳聞我的和親對象是個殘疾皇子苞也,可洞房花燭夜當晚...
    茶點故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內容