文件指纹是指打包后输出的文件名和后缀。

hash一般是结合CDN缓存来使用,通过webpack构建之后,生成对应文件名自动带上对应的MD5值。如果文件内容改变的话,那么对应文件哈希值也会改变,对应的HTML引用的URL地址也会改变,触发CDN服务器从源服务器上拉取对应数据,进而更新本地缓存。

指纹占位符

占位符名称 含义
ext 资源后缀名
name 文件名称
path 文件的相对路径
folder 文件所在的文件夹
hash 每次webpack构建时生成一个唯一的hash值
chunkhash 根据chunk生成hash值,来源于同一个chunk,则hash值就一样
contenthash 根据内容生成hash值,文件内容相同hash值就相同

hash

Hash 是整个项目的hash值,其根据每次编译内容计算得到,每次编译之后都会生成新的hash,即修改任何文件都会导致所有文件的hash发生改变。

module.exports = {entry: {main: './src/index.js',vender: ['lodash']},output: {path: path.resolve(__dirname, 'dist'),filename: '[name].[hash].js'},plugins: [new MiniCssExtractPlugin({filename: "css/[name].[hash].css"})]
};

chunkhash

chunkhash 采用hash计算的话,每一次构建后生成的哈希值都不一样,即使文件内容压根没有改变。这样子是没办法实现缓存效果,我们需要换另一种哈希值计算方式,即chunkhash。

chunkhash和hash不一样,它根据不同的入口文件(Entry)进行依赖文件解析、构建对应的chunk,生成对应的哈希值。我们在生产环境里把一些公共库和程序入口文件区分开,单独打包构建,接着我们采用chunkhash的方式生成哈希值,那么只要我们不改动公共库的代码,就可以保证其哈希值不会受影响。

module.exports = {entry: {main: './src/index.js',vender: ['lodash']},output: {path: path.resolve(__dirname, 'dist'),filename: '[name].[chunkhash].js'},plugins: [new MiniCssExtractPlugin({filename: "css/[name].[chunkhash].css"})]
};

contenthash

使用chunkhash存在一个问题,就是当在一个JS文件中引入CSS文件,编译后它们的hash是相同的,而且只要js文件发生改变 ,关联的css文件hash也会改变,这个时候可以使用mini-css-extract-plugin里的contenthash值,保证即使css文件所处的模块里就算其他文件内容改变,只要css文件内容不变,那么不会重复构建。

module.exports = {entry: {main: './src/index.js',vender: ['lodash']},output: {path: path.resolve(__dirname, 'dist'),filename: '[name].[chunkhash].js'},plugins: [new MiniCssExtractPlugin({filename: "css/[name].[contenthash].css"})]
};

webpack中hash、chunkhash、contenthash相关推荐

  1. webpack中hash、chunkHash、contentHash的区别

    webpack中hash.chunkHash.contentHash的区别 文件目录: index.js依赖common.js和base.less hash Hash:和整个项⽬的构建相关,只要项⽬⽂ ...

  2. webpack 中的 watch cache (下)

    整个 watch 的过程通过事件的机制,完成几个抽象对象的逻辑串联,当触发 Watching.prototype.watch 的调用回调函数时,流程便进入到了另外一端,开始进行重新编译,相较于第一次编 ...

  3. Vue-router 中hash模式和history模式的区别

    Vue-router 中hash模式和history模式的关系 在vue的路由配置中有mode选项 最直观的区别就是在url中 hash 带了一个很丑的 # 而history是没有#的 mode:&q ...

  4. webpack --- [读书笔记] webpack中常用的一些配置项

    1. Webpack 当前Web开发面临的困境 文件依赖关系错综复杂 静态资源请求效率低 模块化支持不友好 浏览器对高级JavaScript特性兼容程度低 1.1 webpack概述 webpack是 ...

  5. 六、Webpack详解学习笔记——webpack的安装、起步、配置、loader的使用、webpack中配置Vue、plugin的使用、搭建本地服务器、webpack配置的分离

    一.认识webpack 什么是webpack? 这个webpack还真不是一两句话可以说清楚的. 我们先看看官方的解释: At its core, webpack is a static module ...

  6. vue文件里在style的样式需要什么loader_Vue学习笔记之Webpack中css、less、图片等文件处理...

    一.webpack中使用css文件: loader是webpack中一个非常核心的概念,去转化webpack不能转化或打包的文件. 安装loader: 官网介绍: 安装: cnpm install - ...

  7. webpack中如何使用vue

    1.安装 vue包:npm i vue -S 2.由于在webpack中,推荐使用.vue这个组件模版文件来定义组件,不然会出现vue.js移动和一些高级语法的不支持,因此需要安装能解析这种文件的lo ...

  8. Use history mode for router? Vue-router 中hash模式和history模式的区别

    再通过vue-cli创建项目的时候,会出现 Use history mode for router? 也就是再问你:是不是用history模式来创建路由 hash模式和history模式的不同 最直观 ...

  9. webpack 打包html中css样式如果处理,webpack中单独打包css样式

    这次给大家带来webpack中单独打包css样式,webpack中单独打包css样式的注意事项有哪些,下面就是实战案例,一起来看一下. 零.介绍 以下是个人项目中总结出来的一些基本知识,记录在这里,加 ...

最新文章

  1. 计算机网络接入接口设备,一种计算机网络集成接口设备的制作方法
  2. finecms如何调用多个指定栏目的内容
  3. HttpClient详解
  4. [rtsp]海康IPC监控摄像头远程外网监控配置(DDNS)
  5. 具体数学_计算机科学基础(第2版)pdf
  6. 热门!实用!游戏rpg制作素材网站推荐!
  7. Ubuntu WPS字体缺失
  8. 桩身弹性压缩计算公式_桩身弹性压缩量计算
  9. 万圣节奇妙夜,不给糖就捣蛋—Python带你点击解锁恐怖新道具(南瓜头、骷髅、蝙蝠、糖......)
  10. PPT| PPT幻灯片演示(持续更新)
  11. SQL消费表中查找所有用户最后一条消费记录
  12. 国产计算机硬件发展史,计算机基础-计算机硬件发展史以及硬件
  13. 盛世昊通董车长2.0,数字化整合行业产业链变革
  14. Jenkins 更新网站静态文件
  15. 一维元胞自动机生命游戏
  16. 操作系统OS linux实验日记
  17. 基于java安防管理平台计算机毕业设计源码+系统+lw文档+mysql数据库+调试部署
  18. Revert R12.1.3 Homepage Layout to Link Style as in R12.1.1 or 11i
  19. 大型连锁超市如何实现视频汇聚
  20. c语言二级考试程序设计题难吗,计算机二级C语言考试程序设计题

热门文章

  1. 百密一疏,防不胜防,细数那些大型数据库建设过程中绕不开的坑
  2. 重大活动网络攻击面前,京东智联云的攻防之道
  3. 写不出满分作文怎么办,GPT-3 来帮你
  4. @程序员,你处在食物链哪级?有人跑车游轮到处玩,有人被房价羞辱,被平庸折磨...
  5. 活跃了 40 年的 AWK 现在怎么样了?
  6. 如何用 Python 快速抓取 Google 搜索?
  7. 跟风 Google 只是东施效颦?!
  8. Web 开发中使用了 Vim 作为主编辑器之后......
  9. 真正勇猛的程序员,敢于让鲁迅崩溃!
  10. 编程面试问题越难越好?!