gpt4 book ai didi

Angular CLI 8 更新 - URL 不再以基本 href 为前缀

转载 作者:行者123 更新时间:2023-12-04 04:22:20 26 4
gpt4 key购买 nike

问题

将我们的 Angular 应用程序更新到版本 8(包括 Angular CLI)后,URL 不再以 angular.json 文件中提供的基本 href 为前缀,这实际上破坏了我们的应用程序

以前的期望行为

在本地提供法语版本的应用程序时,在 localhost:8000 上打开网页会将我重定向到 localhost:8000/fr,以及我可以访问的每个 URL从应用程序内导航到也将以 /fr/ 为前缀。

新的错误行为

在本地提供法语版本的应用程序时,在 localhost:8000 上打开网页会导致一个空页面显示 Cannot GET/,因为 /fr 丢失。当我立即打开位于 localhost:8000/fr 的页面时,我可以看到登录页面,但是由于我们的登录流程涉及第三方,所以当我从第三方返回我们的应用程序时,我只看到一个空白页面,上面写着 Cannot GET/login(因为 /fr/ 丢失)。

到目前为止我尝试过的(非详尽列表,但两种最有希望的方法)

  • AppModule 中提供 APP_BASE_HREF DI token 将使用 LOCALE_ID 作为其值并删除的提供程序angular.json 配置中的 baseHref 设置。这个“有点”工作,因为我从 localhost:8000 重定向到例如localhost:8000/fr/,但它也会导致不需要的重定向因为我假设路由查找逻辑发生在 base href 之前 token 被注入(inject),因此它无法识别 URL 和重定向到默认路由。
  • angular.json 配置中提供了一个 deployUrl 值,但没有用。

类似问题

https://github.com/angular/angular-cli/issues/14925基本上是完全相同的问题。不幸的是,所有这些问题都已关闭,但没有提供有关如何恢复旧行为的实际解决方案。

最佳答案

正如我通过 https://github.com/angular/angular-cli/issues/16179 了解到的那样,实际上这是一开始就不可能发生的旧行为。

在本地运行应用程序时,您一次只能运行一种语言。假设该应用程序默认为德语,运行它将在 localhost:8000 提供服务。运行英文版时,该应用程序将在 localhost:8000/en 提供服务。 Angular CLI 7 和 8 都是如此。版本 8 的变化只是在运行英文版本并导航到 localhost:8000 时,它不会自动将您重定向到 localhost:8000/en。因此,对我们来说,这意味着我们必须稍微调整我们的开发工作流程(只需确保我们在正确的地址打开应用程序),我们的生产环境实际上没有任何变化,因为所有语言都是实时的。

关于Angular CLI 8 更新 - URL 不再以基本 href 为前缀,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58839500/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com