设为首页收藏本站

LUPA开源社区

 找回密码
 注册
文章 帖子 博客
LUPA开源社区 首页 业界资讯 技术文摘 查看内容

使用UglifyJS对JavaScript进行压缩

2014-6-3 11:51| 发布者: joejoe0332| 查看: 2066| 评论: 0|原作者: LeoXu,海王|来自: oschina

摘要: UglifyJS 以其高效的Javascript压缩器而知名. UglifyJS 默认的压缩设置很好用,但还没有发挥出全部潜力. 还有许多的附加指令可以用于压缩选项,包括:……

  UglifyJS 以其高效的Javascript压缩器而知名.  UglifyJS 默认的压缩设置很好用,但还没有发挥出全部潜力.  还有许多的附加指令可以用于压缩选项,包括:


  • sequences — 使用逗号操作符加入连续的简单语句

  • properties — 使用点好重写属性访问,例如foo["bar"] → foo.bar

  • dead_code — 移除不可达的代码

  • drop_debugger — 移除调试器和调试语句

  • unsafe (default: false) — 应用“不安全”的转换(下面会讨论到)

  • conditionals — 为if -s 和条件表达式应用优化

  • comparisons — 针对二进制节点应用某些特定的优化,例如:!(a <= b) → a > b (只在不安全时), 尝试去否认二进制节点,例如.a = !b && !c && !d && !e → a=!(b||c||d||e) 等等.

  • evaluate — 尝试去计算常量表达式

  • booleans — 多种针对布尔上下文的优化,例如 !!a ? b : c → a ? b : c

  • loops — 当我们可以静态的判断条件的取值时,针对do,while和for循环的优化

  • unused — 去掉没有被引用过的函数和变量

  • hoist_funs — 提升函数声明

  • hoist_vars (默认值: false) — 提升var声明 (因为一般看起会增加输出的大小,所以它默认是false的)

  • if_return — 这对 if/return 和 if/continue 的优化

  • join_vars —加入连续的var语句

  • cascade — 对于 sequences, transform x, x into xandx = something(), x into x = something() 的一些小优化

  • warnings — 当去掉不可达代码或者没有被使用的声明等东西时,显示警告.

  • negate_iife — 在返回值被丢弃的地方否认 "即刻调用函数表达式", 来避免代码生成器会插入的括号.

  • pure_getters — 默认为false。如果你传入true, UglifyJS 会假定对象属性访问(例如. foo.bar 或者 foo["bar"]) 不会有任何副作用.

  • pure_funcs — 默认为null. 你可以传入一个名称的数组,而UglifyJs将会假定那些函数不会产生副作用.  危险: 如果名称在作用范围内被重新定义了就不会检查. 这里有一个示例场景, 例如 var q = Math.floor(a/b).  如果变量q没有在别的地方使用, UglifyJS 会去掉它,但是仍然会保留 Math.floor(a/b), 而不清楚它是做什么用的. 你可以传入 pure_funcs: [ 'Math.floor' ] 来让其知道这个函数不会产生任何副作用, 在这种情况下,整个语句会被丢弃.  当前的实现会增加一些开销(压缩会变慢).

  • drop_console — 默认为false.  传入true会丢弃对console.函数的调用.


  因此可以通过 修改布尔值 , 移除不必要var语句,砍掉不可达代码以及其它更多的办法,UglifyJS把你的js文件中多余的东西就挤了出来,而不只是做一下简单的压缩而已. 这里有一个使用NodeJS API的场景示例:

01var UglifyJS = require('uglify-js');
02var fs = require('fs');
03 
04var result = UglifyJS.minify('site.js', {
05    mangle: true,
06    compress: {
07        sequences: true,
08        dead_code: true,
09        conditionals: true,
10        booleans: true,
11        unused: true,
12        if_return: true,
13        join_vars: true,
14        drop_console: true
15    }
16});
17 
18fs.writeFileSync('site.min.js', result.code);


  你也可以通过命令行传入那些压缩值.本文之意义不在开创,而更多的是去提升那种运用起来很简便的意识 —compress 并不会对任何潜在的方面都进行最小化优化.  如果你想要最小化压缩你的js,那就全力以赴吧!


酷毙

雷人

鲜花

鸡蛋

漂亮
  • 快毕业了,没工作经验,
    找份工作好难啊?
    赶紧去人才芯片公司磨练吧!!

最新评论

关于LUPA|人才芯片工程|人才招聘|LUPA认证|LUPA教育|LUPA开源社区 ( 浙B2-20090187 浙公网安备 33010602006705号   

返回顶部