zoukankan      html  css  js  c++  java
  • React-异步组件及withRouter路由方法的使用

      所有组件的代码都打包在bundle.js里,加载首页的时候,把其它页面的代码也加载了,影响首页加载速度。我们希望访问首页的时候只加载首页,访问详情页的时候再去加载详情页的代码。异步组件可以帮我们实现,需要使用第三方依赖“react-loadable”。

    安装

    npm install react-loadable --save

    使用

    一、新建loadable.js

    loadable.js:

    import React , {Component} from 'react';
    import Loadable from 'react-loadable';
    const LoadableComponent = Loadable({
      //意思是当前目录下的index组件是异步加载的
      loader: () => import('./'),
      //加载时临时显示的组件
      loading:()=>{
          return <div>load</div>
      }
    });
    //返回一个无状态组件LoadableComponent
    export default ()=><LoadableComponent/>

    二、修改APP.js

    引入:

    //不再是import Detail from './pages/detail';
    import Detail from './pages/detail/loadable';

    保存刷新页面,结果报下图错。

      这是为什么呢?因为路由"/detail/:id" 对应的组件是loadable.js,而不是之前的index.js,所以在loadable.js里可以获取到this.props.match.params.id,而index.js里获取不到。

    <Route exact path="/detail/:id" component={Detail} />

      有什么解决办法吗?

    三、修改index.js

      需要在index.js里引入react-router-dom的withRouter方法。

    import {withRouter} from 'react-router-dom';

      使用withRouter(Detail)使Detail有能力获取到router里到所有参数。

    export default connect(mapStateToProps,mapDispatchToProps)(withRouter(Detail));
  • 相关阅读:
    Javascript加载执行问题探索
    CentOS搭建WordPress
    ORACLE创建表空间,用户及授权
    ApacheCommonsDbutils 学习笔记
    Android SSL BKS证书生成, 以及PFX与JKS证书的转换
    VirtualBox虚拟机CentOS中安装增强插件失败,解决方法
    ORACLE %TYPE与%ROWTYPE
    Java代码调用C#实现的Web服务
    常用的Git命令
    js手机号正则表达式验证
  • 原文地址:https://www.cnblogs.com/superlizhao/p/9497021.html
Copyright © 2011-2022 走看看