zoukankan      html  css  js  c++  java
  • react-router 4.x

    本次主要总结react中的路由的使用,实现让根组件根据用户访问的地址动态挂载不同的组件。

    1,创建项目

    首先使用命令 npx create-react-app react-router创建项目,然后npm install下载相关依赖,再按照之前的文件目录整理src文件夹,最后再components文件夹下面新建两个组件Home.js和News.js。

     

    2,安装和引入路由

    安装和引入路由可以分为以下几步:

    1. 安装路由:在项目根目录执行命令: npm install react-router-dom --save进行安装
    2. 根组件进行引入import { BrowserRouter as Router, Route, Link } from "react-router-dom"
    3. 修改根组件文件App.js:在根元素中使用<Router>标签对路由组件进行包裹,然后使用组件。

    根据上面的路由配置,当启动项目的时候,显示的是Home组件里面的内容,当我们更改地址栏,在其后面加入/news的后缀以后,就会显示News组件的内容。

     

    在Home组件路由配置中,多了一个单词exact,这个意思是严格匹配,如果去掉这个单词,那么当在地址改为http://localhost:3000/news的时候,就会通过加载两个组件,因为/news也能匹配‘/’这个路径。

     

    3,使用路由

    我们在引入路由的时候,一共引入了三个组件Router, Route, Link,接下来及来使用这最后一个组件。

    在实际运用中,并不会通过手动修改地址栏来进行页面切换,一般都是通过点击事件触发的,在react中,可以借助Link实现a标签进行地址跳转的功能,如下所示,只需要稍微修改根组件App.js就可以了。

    现在当我们点击不同的标签,就会加载不同的页面了。下面贴出app.js的代码:

    import React, { Component } from 'react';
    import './assets/css/App.css';
    import { BrowserRouter as Router, Route, Link } from "react-router-dom";
    import Home from './components/Home';
    import News from './components/News';
    
    class App extends Component {
      render() {
        return (
          <div className="App">
            <Router>
              <div> 
                <header className="title">  
                  <Link to="/">首页</Link>
                  <Link to="/news">新闻</Link>
                </header>
                <Route exact path="/" component={Home} />
                <Route path="/news" component={News} />                    
              </div>
            </Router>
          </div>
        );
      }
    }
    
    export default App;
  • 相关阅读:
    虚拟机的类加载机制
    数组
    Intellij快捷键
    Wireshark过滤器语法设置
    Git命令(转)
    Git命令
    字节码指令简介(转)
    Java异常了解
    Class类文件的结构
    垃圾收集器与内存分配策略(六)之内存分配与回收策略
  • 原文地址:https://www.cnblogs.com/yuyujuan/p/10128703.html
Copyright © 2011-2022 走看看