简单易懂的React魔法(04):用es6语法引入react组件

我们的代码还没有任何输出,因为还没有让index.js包含我们的Detail.js。修改index.js包含以下代码:

src/index.js

import React from 'react';
import ReactDOM from 'react-dom';

import Detail from './pages/Detail';

ReactDOM.render(
    <Detail />,
    document.getElementById('app')
);

保存index.js和detail.js,回到浏览器,会看到页面上的“This is React rendering HTML !“。
在我介绍这些代码是做什么的之前,你可以试着回到detail.js修改它的render方法,使它输出 “This is JSX being converted to HTML!” 如果你这么做了,保存之后,你会发现浏览器自动更新了文字。

不需要手动重新运行webpack来更新修改,webpack dev server 会自动检查这些修改后重新渲染页面,这被称为热加载(hot loading)。希望你现在明白了最开始的时候为什么要花费时间在配置webpack上。如果你发现浏览器没刷新,那你自己手动刷新一下看看。
现在我们解释一下index.js里每行代码的用处:

  • import React from ‘react’引入react,之前你应该看到过。
  • import ReactDOM from ‘react-dom’;这行是新的,这是react操纵dom的工具。
  • import Detail from ‘./pages/Detail’把detail.js里的组件包含到app中。
  • ReactDOM.render()是开始渲染我们整个app的方法,需要连个参数,JSX元素和渲染它的地方。
  • <Detail />是我们需要渲染的元素,作为render的第一个参数,这也是我们Detail组件的名字。
  • document.getElementById(‘app’) 是render的第二个参数。作为react组件的根节点。在这个例子里,我们render在id为app的div中,这个div可以在index.html里找到。

当我们的应用被渲染,<Detail />会被自动转换为我们在Detail.js里创建的组件。调用的是detail的render方法。

现在,在我们继续之前你可能有些问题。我来回答一些:

为什么Detail.js是大写的?

这不是必须的,但是我们习惯这样写,因为react定义组件必须大写首字母。如果在detail.js里声明Detail组件可能会混淆。

JSX怎么知道<Detail />的意思?

我们在Detail.js里不声明组件的名称,而是在它被引入的时候起名字。如果你这样引入import Bob from './pages/Detail'那之后就可以用<Bob />表示这个组件,但是最好别这么用,那样会很混乱。

我能放很多组件在Detail.js里么?

你要想这么做也可以,不过这样也很混乱,最好还是一个文件里面声明一个组件。

我必须渲染组件里的东西么?

不是必须的,不过react确实需要你渲染一些东西。等你react用的多了你就会了解。

总的来说,到目前为止,你已经学会了:

  1. 如何安装webpack,babel和react来用es6语法开发应用。
  2. 如何创建基本react组件并放入应用。
  3. 如何写简单的JSX来渲染文档。

还不错,不过这才刚刚开始……

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,302评论 5 470
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,232评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,337评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,977评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,920评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,194评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,638评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,319评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,455评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,379评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,426评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,106评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,696评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,786评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,996评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,467评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,043评论 2 341

推荐阅读更多精彩内容

  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,125评论 7 35
  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 2,808评论 1 18
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,662评论 7 110
  • 我在18岁的那年遇见了那一群小仙女们,之所以叫他们小仙女,完全是因为他们动不动就说自己是小仙女。 仍记得在炎炎夏日...
    暖宝宝喜欢下雨天阅读 366评论 0 3
  • 这路有千万条, 路可以带你走近繁华的街道, 享受灯红酒绿的生活, 让你沉醉于眼花缭乱的战场上。 路也可以带你走遍乡...
    行情中书阅读 220评论 0 0