在 `npm build` 的输出中添加源路径前缀
Posted
技术标签:
【中文标题】在 `npm build` 的输出中添加源路径前缀【英文标题】:Prefix source paths in the output of `npm build` 【发布时间】:2021-02-14 07:05:33 【问题描述】:我使用 vue-cli 创建了一个小型 vue 应用程序。我使用npm run build
来生成 UI 的生产版本,最终得到一堆 CSS、js 和一个包含所有这些 js 和 CSS 文件的 html 页面文件。但是,为了应用程序的目的,需要将 HTML 移动到不同的目录,中间件可以访问该目录。这就是为什么需要在 js 和 CSS 文件的 URL 前加上前缀,以指向新的目录。是否可以在输出的 HTML 文件中为 js 和 CSS 文件创建前缀?
这里是package.json
的内容:
"name": "investmentapp",
"version": "0.1.0",
"private": true,
"scripts":
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint": "vue-cli-service lint"
,
"dependencies":
"bootstrap": "^4.5.3",
"bootstrap-vue": "^2.18.1",
"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-class-component": "^7.2.3",
"vue-property-decorator": "^8.4.2"
,
"devDependencies":
"@typescript-eslint/eslint-plugin": "^2.33.0",
"@typescript-eslint/parser": "^2.33.0",
"@vue/cli-plugin-babel": "~4.5.0",
"@vue/cli-plugin-eslint": "~4.5.0",
"@vue/cli-plugin-typescript": "~4.5.0",
"@vue/cli-service": "~4.5.0",
"@vue/eslint-config-typescript": "^5.0.2",
"eslint": "^6.7.2",
"eslint-plugin-vue": "^6.2.2",
"typescript": "~3.9.3",
"vue-template-compiler": "^2.6.11"
附:目前,我已经编写了一个单独的脚本来自动执行此操作,但我正在寻找一个内置选项。另外,我很想将其构建到npm run serve
。
【问题讨论】:
【参考方案1】:您可以通过添加可在构建和服务中重复使用的“复制”脚本来复制 package.json 脚本中的文件。
"scripts":
"serve": "vue-cli-service serve && npm run copy",
"build": "vue-cli-service build && npm run copy",
"lint": "vue-cli-service lint",
"copy": "cp src/*.html destinationDir"
,
至于 CSS 和 JS url 的前缀,假设你使用的是 webpack,你可以在 webpack.config.js 中做。大致如下:
output:
filename: '../PrefixDir/[name].[chunkhash].js',
...
,
【讨论】:
很好,我可以在copy
脚本中使用我的python 代码。我不确定是否在 vue-cli-service
的后台使用了 webpack,但我可以检查配置文件。否则,我可能会自己将它与 webpack 结合起来。以上是关于在 `npm build` 的输出中添加源路径前缀的主要内容,如果未能解决你的问题,请参考以下文章
vue-cli 项目中绝对路径引用的相关资源 npm run build 后 打开页面报404错误
为啥“npm install”在我的“package-lock.json”文件中为我的包添加“node_modules”前缀?