最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • react-router hash mode 转为 history mode 踩坑记

    正文概述 掘金(suedar)   2021-01-15   538

    今天老板让我把 hash mode 改为 history mode

    我想这还不简单吗

    import {HashRouter as Router} from 'react-router-dom';
    <Router hashType="noslash">
        <App />
    </Router>
    
    // ----- 转化为----
    
    import {BrowserRouter as Router} from 'react-router-dom';
    <Router>
        <App />
    </Router>
    

    结果你猜怎么着,点击到某个路由,手动刷新后白屏了。 react-router hash mode 转为 history mode 踩坑记

    • Q:为啥会白屏呢?
    • A:是因为 html 里引用的 js 找不到了
    • Q:为啥 hash router 找得到对应的 js 文件,history router 就找不到呢?

    hash 模式下,当前路由为http://localhost::8080/#/square/publish react-router hash mode 转为 history mode 踩坑记 其查找的是根路径下的文件,所以能正确命中对应的资源。

    而在 history 模式下,当前路由为http://localhost::8080/square/publish

    react-router hash mode 转为 history mode 踩坑记

    经测试,http://localhost::8080/square/publish 路径下放的资源,它会在http://localhost::8080/square/ 这个路径下查找。也就是说,在这个设置下,资源路径为相对于当前目录的地址,我们需要将其变为相对于根路径的地址

    那么这个经过 webpack 编译后html 文件中 scriptsrc 是哪里来的呢,让我们看看 webpack 源码

      // eslint-disable-next-line no-unused-vars
      function hotDownloadUpdateChunk(chunkId) {
          var script = document.createElement("script");
          script.charset = "utf-8";
          script.src = $require$.p + $hotChunkFilename$;
          if ($crossOriginLoading$) script.crossOrigin = $crossOriginLoading$;
          document.head.appendChild(script);
      }
    
      ...
    
      const publicPath = this.getPublicPath({
                hash: hash
            });
            buf.push("");
            buf.push("// __webpack_public_path__");
            buf.push(`${this.requireFn}.p = ${JSON.stringify(publicPath)};`); // 这里就是上面的 $require$.p
            return Template.asString(buf);
        });
    
      this.requireFn = "__webpack_require__";
    

    由源码可知,script.src 是经由 $require$.p + $hotChunkFilename$ 拼接而来的,查找 $require$.p 赋值的位置可得,其来源于 publicPath ,由此可得我们修改 webpack 配置

    output: {
        publicPath: '/',
    },
    

    就可将 <script src="[name].[hash:8].bundle.js" /> 转化为 <script src="/[name].[hash:8].bundle.js" />,那么它查找的路径便是相对于根路径,就能正确找到对应的 js 资源了。 react-router hash mode 转为 history mode 踩坑记

    react-router hash mode 转为 history mode 踩坑记


    起源地下载网 » react-router hash mode 转为 history mode 踩坑记

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元