react路由如何安装

这篇文章主要介绍了react路由如何安装的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react路由如何安装文章都会有所收获,下面我们一起来看看吧。

成都创新互联-专业网站定制、快速模板网站建设、高性价比嘉善网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式嘉善网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖嘉善地区。费用合理售后完善,十余年实体公司更值得信赖。

react路由的安装方法:1、通过“npm i react-router-dom@5.0 -S”安装路由;2、使用“import { HashRouter as Router, Route, NavLink } from 'react-router-dom'”方式导入路由即可。

react 路由安装及简单使用

一.react安装路由

安装:npm i react-router-dom@5.0 -S (最新版本为6.0)

导入:

import { HashRouter as Router, Route, NavLink } from 'react-router-dom'

路由配置:

1.所有路由相关内容都应该放在<Router>组件内

2.链接使用:<NavLink to="地址">

3.页面使用:<Route path="地址" component={组件}>

示例:简单的路由跳转

function App() {
    return (<Router>
        <div>
              //exact 精确匹配
            <NavLink to='/' exact>首页</NavLink>|
            <NavLink to='/about' >关于</NavLink>
        </div>
        {/* 路由页面 */}
        <Switch>
            <Route path="/" exact component={Home}></Route>
            <Route path="/about" component={About}></Route>
        </Switch>
    </Router>)
}
export default App
 
function Home() {
    return <div>首页页面</div>
}
 
function About() {
    return <div>
         关于页面    
    </div>
}

二.路由传参

路由传参形式

1.链接传参   <NavLink to="/produce/abc">

2.参数传参  <Route path="/produce/:id">

3.参数获取  props.match.params.id

常用历史操作的方法

1.go()历史跳转记录

2.goBack(返回)

3.push()添加记录跳转

4.replace()替换记录并跳转

示例:

import { HashRouter as Router, Route, NavLink, Redirect, Switch, Prompt, Link } from 'react-router-dom'
// NavLink 会比 link自动添加一个active的class
function App() {
    return (<Router>
        <div>
            <NavLink to='/' exact>首页</NavLink>|
            <NavLink to='/about' >关于</NavLink>
            <NavLink to='/produce/abc'>产品abc</NavLink>
            <NavLink to='/produce/123'>产品123</NavLink>
        </div>
        {/* 路由页面 */}
        <Switch>
            <Route path="/" exact component={Home}></Route>
            <Route path="/about" component={About}></Route>
            <Route path="/produce/:id" component={Produce}></Route>
        </Switch>
    </Router>)
}
export default App
 
function Produce({ match, history, location }) {
    // console.log(match);
    return (<div>
        <h2>产品{match.params.id}</h2>
        <button onClick={() => history.goBack()}>返回</button>
        <button onClick={() => history.push('/')}>回到首页</button>
    </div>)
}
 
function Home() {
    return <div>首页页面</div>
}
 
function About() {
    return <div>关于页面
    </div>
}

子路由传参

示例:

// 导入路由相关组件
// 导入哈希路由 别名router
// Route路由页面
// NvaLink 导航链接
import { HashRouter as Router, Route, NavLink, Redirect, Switch, Prompt, Link } from 'react-router-dom'
// NavLink 会比 link自动添加一个active的class
function App() {
    return (<Router>
        <div>
            <NavLink to='/' exact>首页</NavLink>|
            <NavLink to='/about' >关于</NavLink>
            <NavLink to='/produce/abc'>产品abc</NavLink>
            <NavLink to='/produce/123'>产品123</NavLink>
            <NavLink to='/admin'>管理</NavLink>
        </div>
        {/* 路由页面 */}
        <Switch>
            <Route path="/" exact component={Home}></Route>
            <Route path="/about" component={About}></Route>
            <Route path="/produce/:id" component={Produce}></Route>
            <Route path="/admin" component={Admin}></Route>
        </Switch>
    </Router>)
}
export default App
function NoMatch({ location, history }) {
    return (<div>
        <h2>404</h2>
        <p>你爹来咯</p>
        <p>{location.url}</p>
        <button onClick={history.goBack}>后退</button>
        <NavLink to={{ pathname: "/" }}>首页</NavLink>
 
    </div>)
}
function Admin() {
    return (<div style={{ "display": "flex" }}>
        <div style={{ width: "200px", boderRight: "1px solid #f0f0f0" }}>
            <NavLink to="/admin/dash">概览</NavLink><br />
            <NavLink to="/admin/orderlist">列表</NavLink>
        </div>
        <div>
            <Route path="/admin/dash" component={Dash}></Route>
            <Route path="/admin/orderlist" component={OrderList}></Route>
            <Redirect path='/admin' to="/admin/dash"></Redirect>
        </div>
    </div>)
}
function Dash() {
    return (<div>
        概览
    </div>)
}
function OrderList() {
    return (<div>
        订单列表
    </div>)
}
function Produce({ match, history, location }) {
    // console.log(match);
    return (<div>
        <h2>产品{match.params.id}</h2>
        <button onClick={() => history.goBack()}>返回</button>
        <button onClick={() => history.push('/')}>回到首页</button>
    </div>)
}
 
function Home() {
    return <div>首页页面</div>
}
 
function About() {
    return <div>关于页面
    </div>
}

关于“react路由如何安装”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“react路由如何安装”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注创新互联行业资讯频道。

网站题目:react路由如何安装
本文链接:https://www.cdcxhl.com/article38/gjgssp.html

成都网站建设公司_创新互联,为您提供品牌网站制作小程序开发网站设计公司自适应网站标签优化网站改版

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

微信小程序开发