【问题标题】:vue-router and Expressvue-router 和 Express
【发布时间】:2017-10-28 19:49:40
【问题描述】:

我使用 Vue.js 和他们的 vue-cli webpack 构建了一个简单的应用程序。

我使用 vue-router 来控制具有不同视图的站点导航。这在本地运行时工作正常。

我现在想将它部署到 Heroku,但是 URL 不再有效。我试过实现中间件,但碰壁了!

我正在寻找可能引导我正确配置 node.js/express 以正确运行应用程序的东西。

非常感谢,

詹姆斯

【问题讨论】:

  • 您是否在路由器中添加了mode: history 并配置了您的服务器。看这里 (router.vuejs.org/en/essentials/history-mode.html) 来配置 Node.js(Express)
  • 我做到了。因此,当在本地运行时,在 localhost:4444 上运行“npm run dev”,它可以完美运行。在 Heroku 上运行时,我得到主页,但在加载任何其他页面时我得到“CANNOT GET /login”。
  • 即使在配置您的服务器之后?
  • 这就是我需要帮助的地方。我不太清楚 server.js 中应该包含什么。当单击它们作为路由器链接时,这些链接按预期工作,但在直接访问路径时不会。

标签: node.js express heroku vue.js


【解决方案1】:

对于那些处于类似情况的人,现在正在使用:

const express = require('express');
const history = require('connect-history-api-fallback');
const app = express();

const staticFileMiddleware = express.static(__dirname);
app.use(staticFileMiddleware);
app.use(history({
  disableDotRule: true,
  verbose: true
}));
app.use(staticFileMiddleware);

const port = 5555;
app.listen(port, () => {
  console.log(`Example app listening on port ${port}!`);
});

您可以了解更多关于connect-history-api-fallback

【讨论】:

  • 很好,您通过参考链接提供了答案。这将帮助任何有同样疑问的未来用户
  • 静态中间件 is 实际上需要两次:一次是为了防止静态文件被 404ing,一次是为了在 history 重定向之后解析 index.html。请注意,这一切都必须在定义其他 Express 路线之后完成。
  • 与服务器一起运行时,我遇到了同样的错误“CANNOT GET /page”。这对我有用!
  • 它也对我有用。在我的情况下,我需要为 staticFileMiddleware 添加express.static(path.join(__dirname, 'dist')),因为我在 dist 文件夹中服务。
  • @spiffytech 谢谢你的解释。文档中没有提到重要的事情真是太疯狂了。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-07-04
  • 2017-05-23
  • 2020-05-07
  • 2023-03-06
  • 2021-03-02
  • 2017-03-14
  • 2023-03-24
相关资源
最近更新 更多