webpack中hash、chunkhash、contenthash区别

  1. hash
    如果都使用hash的话,因为这是工程级别的,即每次修改任何一个文件,所有文件名的hash至都将改变。所以一旦修改了任何一个文件,整个项目的文件缓存都将失效。
  2. chunkhash
    chunkhash根据不同的入口文件(Entry)进行依赖文件解析、构建对应的chunk,生成对应的哈希值。在生产环境里把一些公共库和程序入口文件区分开,单独打包构建,接着我们采用chunkhash的方式生成哈希值,那么只要我们不改动公共库的代码,就可以保证其哈希值不会受影响。
    这样就会有个问题,只要对应css或则js改变,与其关联的文件hash值也会改变,但其内容并没有改变呢,所以没有达到缓存意义。
  3. contenthash
    contenthash是针对文件内容级别的,只有你自己模块的内容变了,那么hash值才改变,
posted @ 2019-02-26 11:15  IT农工  阅读(287)  评论(0编辑  收藏  举报