- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 Angular 5 应用程序中,我一直通过 ng serve
在本地运行,一切都运行良好。然后我执行了 ng build -prod
并将 dist 文件夹上传到我的网络服务器。
主页打开并正确显示,但我尝试去的任何路由都导致 404 错误。我不知道如何调试/修复此问题。
最佳答案
首先,如上所述,您需要确保使用 [routerLink]
指令在应用程序内部进行路由。使用 href
s 基本上是告诉你的浏览器导航到一个新的路由,结果会向服务器发出页面请求并呈现新内容(这就是为什么你收到 404
,该路由在服务器上不存在,它只是由您的 Angular 应用程序解释)。
[routerLink]
指令有效地更新应用程序内部的路由,同时更新浏览器的导航历史记录,而无需实际获取新页面。较旧的应用程序实际上使用 hashbang
策略,而我们正在讨论 push state
策略......(Both discussed here if you're interested in learning more)
无论哪种方式,就像@Ritwick 提到的那样。此时,如果用户从应用程序外部导航到您可以处理的路由,您将希望将所有服务器请求重定向到您的 index.html
。正如一些示例片段一样,如果您使用的是 NGINX
,您可以执行此路由重定向:
index index.html;
location / {
try_files $uri $uri/ /index.html;
}
或者如果您使用的是 Firebase 之类的东西,您可以像这样更新您的 firebase.json
...
{
"hosting": {
"public": "dist", // if your app is in a subfolder of the dist, include that
"rewrites": [
{
"source": "**",
"destination": "/index.html"
}
]
}
}
关于部署后 Angular 5 路由不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50648762/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!