安装 node.js;node
安装 cnpm;react
安装 yarn;
安装完成yarn
后, 将镜像替换成国内的:git
$ yarn config set registry 'https://registry.npm.taobao.org'
安装 create-react-app:github
$ sudo cnpm install -g create-react-app // 查看安装版本 $ create-react-app --version 1.3.3
命令行切到须要建立项目的目录内, 而后执行:web
// my-app 是项目的名称, 也是文件夹的名称 $ create-react-app my-app // 命令行切到刚建立的项目 $ cd my-app // 运行项目 // 执行如下命令会自动打开浏览器, 并防问 http://localhost:3000/ $ yarn run start
初始化生成的文件先无论, 作项目仍是得好好的分目录的哟, 接下来安装react-routernpm
由于, 是在浏览器内运行的, 因此安装react-router-dom
; 命令行切到刚建立的项目目录内, 而后执行安装:segmentfault
$ yarn add react-router-dom // 我这里安装的是 ^4.1.2 版本的
好了, 路由也有了, 如今能够开始写项目啦.浏览器
在src
目录内建立一个comonents
目录, 用来放组件;react-router
建立咱们本身的首页: 在components
目录内建立一个Home
目录, 而后再Home
目录内建立一个Home.js
, 写入如下内容:app
// 组件必须先 import 进 react; import React from 'react'; const Home = () => ( <div> <h1>这是首页</h1> </div> ); export default Home;
建立about
页面: 在components
目录内建立一个About
目录, 而后再About
目录内建立一个About.js
, 写入如下内容:
import About from 'react'; const About = () => ( <div> <h1>这是关于页</h1> </div> ); export default About;
如今咱们有两个组件了, 可是还没办法在浏览器内防问, 接下来建立路由:
先清空src/App.js
内的内容, 而后写入如下内容:
import React from 'react'; import { BrowserRouter as Router, Route, } from 'react-router-dom'; import Home from './components/Home/Home'; import About from './components/About/About'; const App = () => ( <Router> <div> <Route exact path="/" component={Home} /> <Route path="/about" component={About} /> </div> </Router> ); export default App;
如今命令行切到项目根目录, 执行yarn run start
启动项目, 会自动在浏览器内防问 http://localhost:3000/, 这就是咱们的 首页
组件哟, 能够手动修改url
防问 关于页(http://localhost:3000/about)
组件.
咱们建立了两个组件, 而且都有本身的独立路由, 可是要防问须要手动输入, 太麻烦啦, 那咱们能够建立一个 导航
组件:
在 components
目录下建立一个 Common
文件夹并建立 NavBar.js
内容以下:
import React from 'react'; import { Link, } from 'react-router-dom'; const NavBar = (props) => ( <ul> <li><Link to="/">Home</Link></li> <li><Link to="/about">About</Link></li> <li>来源于: { props.title }</li> </ul> ); export default NavBar;
如今咱们有一个公共组件了, 接下来把它放到 Home
和 About
组件内:Home
内容以下:
import React from 'react'; import NavBar from '../Common/NavBar'; const Home = () => ( <div> <NavBar title="首页" /> <h1>这是首页</h1> </div> ); export default Home;
About
内容以下:
import React from 'react'; import NavBar from '../Common/NavBar'; const About = () => ( <div> <NavBar title="关于页" /> <h1>这是关于页</h1> </div> ); export default About;
如今命令行切到项目根目录, 执行yarn run start
启动项目, 在浏览器内查看效果;
虽然, 咱们如今有一个组件了, 可是内容都特别单调, 接下来建立一个列表的组件:
在 components
目录下建立一个 List
文件夹并建立 List.js
内容以下:
import React from 'react'; import NavBar from '../Common/NavBar'; const List = () => { const data = [{ name: '小白', age: 5 }, { name: '大黄', age: 3 }]; const dataDom = [ <li key="1">1号</li>, <li key="2">2号</li> ]; return ( <div> <NavBar title="列表页" /> <ul> { data.map((item, index) => ( <li key={index}> <strong>名字:</strong> <span>{item.name}</span> <strong>大小:</strong> <span>{item.age}</span> </li> )) } { dataDom } </ul> </div> ); }; export default List;
建立完成后, 修改 src/App.js
将咱们的列表组件添加到路由中:
import React from 'react'; import { BrowserRouter as Router, Route, } from 'react-router-dom'; import Home from './components/Home/Home'; import About from './components/About/About'; import List from './components/List/List'; const App = () => ( <Router> <div> <Route exact path="/" component={Home} /> <Route path="/about" component={About} /> <Route path="/list" component={List} /> </div> </Router> ); export default App;
修改 src/components/Common/NavBar.js
:
import React from 'react'; import { Link, } from 'react-router-dom'; const NavBar = (props) => ( <ul> <li><Link to="/">Home</Link></li> <li><Link to="/about">About</Link></li> <li><Link to="/list">List</Link></li> <li>来源于: {props.title}</li> </ul> ); export default NavBar;
如今命令行切到项目根目录, 执行yarn run start
启动项目, 在浏览器内查看效果;
第一步就先到这里啦: 源码
React.js组件化开发第二步(添加样式及数据请求)