代码之家  ›  专栏  ›  技术社区  ›  Wouter van Vliet

当没有匹配项时从ReactRouter中断

  •  2
  • Wouter van Vliet  · 技术社区  · 6 年前

    我们在洒些水 react-router 在现有的多页应用程序上,打算慢慢过渡到SPA设置。使用时出现问题 Link 链接到尚未由处理的页面 Router .

    Route ,它将呈现加载微调器,并应负责重定向、重新加载或触发浏览器的整页重新加载并显示旧服务器呈现的页面所需的任何操作。这是有效的。。。

    不管我用什么 window.open , window.location.assign ,或 window.location.replace ,当我按下后退按钮时 onpopstate 地址栏中的URL发生变化,但是 反应路由器

    唯一有效的,但肮脏的,解决办法将是稍微改变URL(fx添加?或字符)和使用 window.location.replace文件 使浏览器进行刷新。但这感觉不对。

    非常感谢任何帮助。。

    1 回复  |  直到 6 年前
        1
  •  1
  •   Wouter van Vliet    6 年前

    找到了一个有效的解决方案;

    const initialPage = document.location.href.replace(/#.*/, '');
    window.addEventListener('popstate', () => {
        if (!isAppPage()) {
            const newPage = document.location.href.replace(/#.*/, '');
            if (newPage !== initialPage) {
                window.location.reload();
            }
        }
    });
    

    在哪里? isAppPage 是一个可以判断我们是否处于SPA模式的函数。

    我正在记录initialPage并将其与新页面进行比较,以便在不触发重新加载的情况下通过#哈希导航。