vue在打包的时候能不能固定assets里的js和css文件名称

在 Vue 项目中(特别是使用 Vue CLI 构建的项目),打包时生成的 assets 目录下的 .js 和 .css 文件默认会带有哈希值(如 app.123abc.js),这是为了缓存优化。但你可以配置固定名称,方法如下:

方法一:Vue CLI 修改 vue.config.js

在项目根目录创建或修改 vue.config.js 文件,添加如下配置:

复制代码
module.exports = {
  // 关闭文件名中的 hash 值
  filenameHashing: false,

  // 自定义输出文件名
  configureWebpack: {
    output: {
      filename: 'js/[name].js',
      chunkFilename: 'js/[name].js'
    }
  },

  css: {
    extract: {
      filename: 'css/[name].css',
      chunkFilename: 'css/[name].css'
    }
  }
}

🔍 参数说明:

  • filenameHashing: false:关闭自动生成的 [hash],让文件名保持固定。

  • output.filename:主入口 JS 文件名。

  • output.chunkFilename:分包/异步加载的 JS 文件名。

  • css.extract.filename:主 CSS 文件名。

  • css.extract.chunkFilename:异步 CSS 文件名。

构建后目录结构示例:

复制代码
dist/
  ├── index.html
  ├── js/
  │   ├── app.js
  │   └── chunk-vendors.js
  └── css/
      ├── app.css
      └── chunk-vendors.css

注意事项:

  1. 关闭哈希可能导致浏览器缓存问题,除非你使用文件版本控制或手动清缓存。

  2. 如果你使用的是 Vite 而不是 Vue CLI,配置方式会不同。

  3. 以上配置适用于 vue-cli@3/4/5。

Vite 方式

复制代码
build: {
  rollupOptions: {
    output: {
      entryFileNames: 'assets/js/[name].js',
      chunkFileNames: 'assets/js/[name].js',
      assetFileNames: ({ name }) => {
        if (name && name.endsWith('.css')) {
          return 'assets/css/[name].[ext]';
        }
        return 'assets/[name].[ext]';
      }
    }
  }
}

输出示例

复制代码
dist/
├── index.html
└── assets/
    ├── js/
    │   ├── main.js
    │   └── vendor.js
    └── css/
        └── style.css
相关推荐
qq_1777673715 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
web打印社区15 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO15 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
烬头882115 小时前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu1213815 小时前
Vuex介绍
前端·javascript·vue.js
2601_9498095916 小时前
flutter_for_openharmony家庭相册app实战+相册详情实现
javascript·flutter·ajax
qq_1777673716 小时前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
2601_9498333916 小时前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter
2601_9494800616 小时前
【无标题】
开发语言·前端·javascript
css趣多多16 小时前
Vue过滤器
前端·javascript·vue.js