微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Vue CLI 使用相对路径部署到子文件夹

如何解决Vue CLI 使用相对路径部署到子文件夹

使用 Vue CLI 和 Vue 2。

有谁知道如何使用相对路径构建项目,所以我可以将它放在我服务器的任何子文件夹中,它会起作用吗? (例如www.mysite.com/subfolder/

我试过了

// vue.config.js
module.exports = {
  publicPath: "",};

它构建相对路径(即,js/app.js 而不是 /js/app.js),但应用程序不会加载。页面上没有显示任何内容

最奇怪的是,所有文件都正确加载(我可以在 Chrome devtools 中的网络选项卡上检查),没有 JS 错误等。所以页面正在加载所有文件,但似乎在使用时拒绝挂载应用程序相对路径。

我知道我可以在构建过程中添加绝对路径,但这不是我需要的。我的客户需要能够将文件一个文件夹自由移动到另一个文件夹,并且该应用程序应该可以运行而无需重新编译

PS:也试过用 Vite 和 Vue 3 构建项目,同样的问题。

谢谢!

解决方法

好吧,看起来只需要:

  1. 使用相对 publicPath(空字符串)构建
// vue.config.js
module.exports = {
  publicPath: "",};
  1. 在最终的 HTML 中添加一个 <base> 标签...
<base href="/subfolder/" />

对于Vite,导出应该是

// vite.config.js
export default {
  ...
  base: "",};

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?