最小化JS和CSS有什么风险吗?
Is there any risk in minifying JS and CSS?
我在嵌入式系统上有一个复杂的web应用程序,很快它将通过测试。目前,所有文件都以其源代码形式进行调试。我绝对需要最小化所有的JS和CSS,我想知道是否有任何的机会,有些事情可能会出错。测试最小化的代码更好还是测试源代码状态更好?
谢谢。
如果宇宙射线穿透构建服务器的外壳并在缩小过程中击中内存,它可能会破坏一切。不过,这种可能性非常小。
构建中的另一个步骤总是会引入复杂性并有潜在的错误,特别是当它修改文件时。您的测试将发现,由于您应该始终测试您计划将部署到生产环境中的内容。如果您部署了被缩减的代码,则需要测试被缩减的代码。
最小化被广泛使用,大多数工具都相当成熟和健壮,在检测什么正在使用和什么没有使用方面具有出色的准确性。它们非常善于不删除以不寻常方式使用的代码。
然而,minifier有可能决定某些东西没有被使用并且是不正确的。在这种情况下,你的单元和/或集成测试应该失败,你将能够更改代码或告诉minifier保留缺失的部分。
这些修复非常快,而且通常很明显,所以拥有几个小文件(而不是许多大文件)的好处几乎总是大于它们。因为minifiers会重命名代码或者完全删除代码,所以即使是简单的烟雾测试也足以暴露任何错误。
作为一个例子,Google的闭包编译器有一个关于处理全局变量和外部变量、导出和你需要保留的未使用代码的教程。
一般来说,原始代码和简化后的代码在功能上没有区别。最小化过程应该只在最小化代码时对其进行安全更改。
然而,我总是说,任何复杂到真正有用的系统,也有bug。即使你不太可能偶然发现最小化代码中的错误,它仍然是可能的。
我建议您测试已缩减的代码。您也许可以使用未简化的代码运行第一个测试,因为调试未简化的代码要容易得多。
- 什么'获取数组的已定义部分的最快方法是什么?JS
- 正确的使用方式是什么.js与网络工作者
- 使用什么js函数来切换侧边栏
- 在 Backbone 中侦听和修改模型属性的正确方法是什么.js
- 骨干网的基本目的和好处是什么.js
- 科尔多瓦使用什么js“引擎”
- 制造灰尘的侵入性最小的方法是什么.js能够提前渲染打字.js模板
- 使用iOS 8“扫描信用卡”功能时,输入字段上触发了什么JS事件
- 黄瓜的建议 ide 或插件是什么.js
- 读取视频中的视频元素/属性的正确方法是什么.js
- 实现 Porthole 的正确方法是什么.js根据内容高度调整 iframe 的大小
- 培根中的惰性评估是什么.js
- 使用下划线对数组进行分类的最快方法是什么.js.
- 培根的评价模型是什么.js
- d3背后的逻辑是什么.js nice()刻度
- Facebook的调度程序中使用的语法是什么.js
- 这是什么:js
- 什么===!JS中的操作符
- “未捕获的TypeError: Cannot read”属性是什么?JS误差均值
- 在Storify中使用什么js框架进行用户界面开发