React 使用 路由


react-router 基础知识 安装 安装 react-router npm install react-router --save,完成之后可查看package.json的变化。这里我使用的是3.0.5的版本,4.x之后会有变化 本章节演示 react-router 的一些基本用法,为了能让大家快速了解。接下来的项目开发中,可能会有另外的用法(应该不多),到时候遇到再讲。当然也欢迎大家去官网文档自己提前学习。 创建页面 创建以下几个页面,用于演示 ./app/containers/App.jsx 所有页面的外壳 ./app/containers/Home 主页 ./app/containers/List 列表页 ./app/containers/Detail 详情页 ./app/containers/NotFound 404 注意App.jsx中的代码目前是这样子的,而且放在这里有点多余,但是在正式的项目开发中,这个文件很有用,而且这个文件和react-router也将会结合的很好。 class App extends React.Component { render() { return ( <div>{this.props.children}</div> ) } } 配置 router 创建 ./app/router/routeMap.jsx 文件,主要代码如下,详细的代码看源文件。 class RouteMap extends React.Component { updateHandle() { console.log('每次router变化之后都会触发') } render() { return ( <Router history={this.props.history} onUpdate={this.updateHandle.bind(this)}> <Route path='/' component={App}> <IndexRoute component={Home}/> <Route path='list' component={List}/> <Route path='detail/:id' component={Detail}/> <Route path="*" component={NotFound}/> </Route> </Router> ) } } 注意,代码中path='detail/:id',最后一个标记表示参数,例如/detail/123这个123就是参数,具体的使用在下文详解。 还要注意,<Route>是可以嵌套的,上面的代码中只嵌套了一层,在后面的项目开发中,可能会嵌套层次多一些,不过是一个道理 使用 router ./app/index.jsx中的代码如下,这样就使用了我们刚才定义的routeMap组件 import React from 'react' import { render } from 'react-dom' import { hashHistory } from 'react-router' import RouteMap from './router/routeMap' render( <RouteMap history={hashHistory}/>, document.getElementById('root') ) 注意这里的hashHistory,规定用 url 中的 hash 来表示 router 例如localhost:8080/#/list。与之对应的还有一个browserHistory也可用,它就不使用 hash ,直接可以这样localhost:8080/list表示。但是后者需要服务器端支持,我们这里用前者。两者在前端开发中,使用起来都是一样的,只是表示形式不一样。 到此为止就可以npm start运行看效果了。 页面跳转 从给一个页面跳转到另一个页面,有两种方法。第一种是 <Link> 跳转,例如在 Home 页面中的代码。(其实这个<Link>渲染完了就是html中的<a>) import React from 'react' import { Link } from 'react-router' class Home extends React.Component { render() { return ( <div> <p>Home</p> <Link to="/list">to list</Link> </div> ) } } export default Home 另一个方法是使用 js 跳转,例如在 List 页面中 import React from 'react' import { hashHistory } from 'react-router' class List extends React.Component { render() { const arr = [1, 2, 3] return ( <ul> {arr.map((item, index) => { return <li key={index} onClick={this.clickHandler.bind(this, item)}>js jump to {item}</li> })} </ul> ) } clickHandler(value) { hashHistory.push('/detail/' + value) } } export default List 获取参数 Detail 页面需要获取 url 中的id参数,否则配置这个参数就无用了。可以使用 this.props.params.id 获取, 作者: weixin_iverson_2 链接:http://www.imooc.com/article/14956 来源:慕课网

 

posted @ 2017-09-26 00:00  伍声2016  阅读(193)  评论(0编辑  收藏  举报