- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人可以告诉我 [hash] 和 [chunkhash] 的目的是什么以及它们来自哪里吗?
output: {
path: "/home/proj/cdn/assets/[hash]",
publicPath: "http://cdn.example.com/assets/[hash]/"
}
最佳答案
这一点对我来说暂时并不明显,所以我认为它值得一些更详细的解释。
官方文档内容:
来自官方的简单说明documentation关于他们的目的:
A simple way to ensure the browser picks up changed files is by using
output.filename
substitutions. The[hash]
substitution can be used to include a build-specific hash in the filename, however it's even better to use the[contenthash]
substitution which is the hash of the content of a file, which is different for each asset.
再一一解释来自documentation的output.filename
:
[hash]
是“为每个构建生成的唯一哈希值”[chunkhash]
是“基于每个 block 的内容”[contenthash]
是“为提取的内容生成的”让我们通过示例使其更容易理解:
我的src
中有3个文件目录:index.js
, index.css
, vendors.js
我的示例 Webpack 配置中的相关部分:
(不是完整的工作配置!)
entry: {
index: ["./src/index.js", "./src/index.css"],
vendors: ["./src/vendors.js"]
},
output: {
filename: "[name].[hash].js"
}
plugins: [
new MiniCssExtractPlugin({
filename: "[name].[hash].css"
})
]
所以我有 2 个 block 名称,index
和vendors
,但是看看index
chunk 还将有 css
内容,因为它导入了 css
数组中的文件。构建时,css
部分将使用 MiniCssExtractPlugin
导出到单独的文件(就我而言)但 Webpack 知道 index.js
和index.css
属于同一个 block 。
现在让我们尝试使用不同的哈希类型来构建它。 (同样更改两个 filename
选项)
使用[哈希]:
每个文件都有相同的哈希值,因为 [hash]
是根据我们所有使用的源文件生成的。如果我重新运行构建而不更改任何内容,生成的哈希将保持不变。如果我只编辑一个文件,那么哈希值将会更改,并且我生成的所有 bundle 的名称中都将包含此新哈希值。
使用 [chunkhash]:
如您所见,第一个和第二个文件来自同一个 index
block ,因此它们的名称中具有相同的哈希值。这是因为[chunkhash]
是根据给定 block 的全部内容生成的。所以如果我编辑的话,比如 index.css
并重新构建来自 index
的文件chunk 将有一个新的哈希值,但来自 vendors
的哈希值 block 将保持与之前相同。
使用 [contenthash]:
这一点是显而易见的。每个生成的文件的名称中都有一个唯一的哈希值,该哈希值是根据该文件的内容计算得出的。如果我改变的话,比如 index.css
重新构建,仅生成index.css
将有一个新的哈希值。
关于javascript - webpack [hash] 和 [chunkhash] 的用途是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35176489/
XML可以应用于 WEB 开发的许多方面,常用于简化数据的存储和共享 XML 把数据从 HTML 分离 现在的HTML 文档一般都是显示动态数据,每当数据改变时将花费大量的时间来编辑 HTML
在类(class)(方案)中,我们最近学习了允许函数接受任意数量参数的语法,例如; (define len (lambda args (length args))) >(len 1 2 3
在 redis-cli 中执行 info 命令时,会列出与该服务器相关的所有信息。 “evicted_keys”的目的是什么? 最佳答案 Redis 可以配置为根据需要自动清除键。如果这样配置,red
golang 空结构体 struct{} 可以用来节省内存 ? 1
有人可以解释一下资源文件夹中的 Info.plist 是什么吗?我如何在我的应用程序中使用它?提前致谢。 最佳答案 您可以在Info.plist文件中为所有类型的设备指定不同的常规资源和应用程序配置,
我需要减小可执行文件的大小,并且经常在我的可执行文件中将某些“不必要的” uses占用一定的大小。 例如: Unit1连接到Unit2,但是两个单元的导入为“ System.SysUtils”。 然后
我是 OOP 的新手。虽然我了解多态是什么,但我无法真正使用它。我可以有不同名称的函数。为什么我应该尝试在我的应用程序中实现多态性。 最佳答案 在严格类型化的语言中,多态性对于拥有不同类型对象的列表/
Possible Duplicate: What is the difference between a delegate and events? Possible Duplicate: Differ
这个问题在这里已经有了答案: Custom index.html javadoc page? (2 个答案) 关闭 7 年前。 我使用的是eclipse。一般情况下我们可以使用javadoc.exe
你能解释一下吗ValidateAntiForgeryToken目的并向我展示有关 MVC 4 中的 ValidateAntiForgeryToken 的示例? 我找不到任何解释此属性的示例? 最佳答案
我正在学习 RxSwift 并试图了解 Observable 和 PublishSubject aka Sequence 之间的主要区别。 据我了解,Sequences/PublishesSubjec
有时有人说,在使用 Azure 表时,实际上存在第三个关键分区数据 - 表名称本身。 我在执行分段查询时注意到 TableContinuationToken 有一个 NextTableName 属性。
在Apple提供的aurioTouch项目中,听说在performRender()函数下的AudioController文件中的AudioBufferList ioData携带了mic到音频播放器的音
MSDN 文档没有详细解释它的用途。 由于它是可选的,我几乎假设它类似于某种元数据。 我现在如何看待它,我想用它来为特定用户指定缓存,例如: new CacheItem(key: "keyName",
我正在学习 browserify,我正在尝试用它做两件基本的事情: 转换(通过 shim)非 CommonJS 模块以实现易用性和依赖跟踪 捆绑项目特定的库 我找到了一个工作流程,说明如何使用 Gul
我通过按 CTRL + C 访问 eix 1.8.2 的 Break 菜单。它看起来像这样: BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded
在 codeLabs 教程(Android - Kotlin - Room with a View)中,他们使用“viewModelScope.launch(Dispatchers.IO)”来调用插入
我通过按 CTRL + C 访问 eix 1.8.2 的 Break 菜单。它看起来像这样: BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded
请耐心等待,因为我没有太多地使用压缩算法,所以这对你们中的一些人来说可能是显而易见的。当某些流媒体视频开始滞后时,我总是注意到这一点。当我看到这个问题时我才意识到我很好奇: Twitter image
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 3 年前。 Improv
我是一名优秀的程序员,十分优秀!