UglifyJS 新一代的Javascript压缩工具
2011-04-09 10:56
447 查看
偶然的机会在老赵的博客上(http://blog.zhaojie.me/tag/UglifyJS/)看到了这篇文章,看到jQuery 1.5的压缩工具由google Closure Compiler 改为UglifyJS。感到了非常惊讶,google大佬也有挨打的时候,有此推荐国外科技发展的氛围。不像国内动不动专家。。。。我见到的专家都是政客的傀儡。。。也许因为我是小菜,呵呵呵。。。。
下面说说的我的劳动成果。
UglifyJS在他的官网上下载的 mishoo-UglifyJS-v1.0.1-3-g0fa93d2.zip不能在windows下执行,那是在linux下执行。有此感到很郁闷都说好自己不能亲自试试,于是就在google上查找他的资料。
终于找到了可以使用java执行的UglifyJS的库。
https://github.com/yuanyan/UglifyJS-java上下载了yuanyan-UglifyJS-java-c530baf.zip解压后发现里面根本没有他的ReadMe里面所说的UglifyJS-java.jar文件,但是他给了所有的java的源文件。
不知道为什么?因为有很多不用java开发也用jQuery开始程序的兄弟们编译起来很费劲,我编译了一个请各位小菜们使用,UglifyJS-java原作者不要有什么想法,假如有请通知我,我会在我的资源中删除。
UglifyJS.jar 下载地址我的资源中查找或者下面的地址
http://download.csdn.net/source/3173876
注意:UglifyJS-java必须运行在jre 1.6以上
下面是UglifyJS的使用选项 下面的内容摘自网上,
非常感谢作者http://www.tanbo.name/a/js_jquery/20110330/118.html
uglifyjs [ 选项... ] [ 文件 ]
文件参数应该放在选项后面,uglifyjs 会读取文件中的javascript代码进行处理。
如果你不指定输出的文件名,那么他会把处理后的内容输出到命令行中。
例: uglifyjs 1.js 2.js 会创建一个 2.js 文件把 1.js处理完毕的内容输入到这里
例: uglifyjs 1.js 会读取1.js内容,并把结果输出到命令行中。
支持的选项:
-b or --beautify — 参数 -b 或者 --beautify 用于美化(格式化)代码。美化之前会压缩代码(未验证。)
-i N or --indent N — 缩进级别空格数
例:uglifyjs -b 1.js 2.js 会把1.js的内容格式后输出到2.js
-q or --quote-keys — quote keys in literal objects (by default, only keys that cannot be identifier names will be quotes).
-nm or --no-mangle — 变量名不缩短,意味着不会把代码的变量名缩短为 abcdefg
-ns or --no-squeeze — 不使用ast_squeeze()(可以使各种优化之后的代码更小,更具有可读性。)
-mt or --mangle-toplevel — mangle names in the toplevel scope too (by default we don’t do this).
--no-seqs — 当ast_squeeze()被调用的时候(除非你添加了--no-squeeze 参数才不会被调用)它将减少在一个代码块中重复声明的行。例如:“a = 10; b = 20; foo();”将被重写为“a=10,b=20,foo();”。在各种场合,这将允许我们丢弃代码块中的括号(在一些语句块变成一个独立的声明行之后)。这是默认的,因为经我们测试,它似乎更安全并且能节省几百bytes,但加上--no-seqs 后将被禁止。
--no-dead-code — 默认情况下,UglifyJS将会删除代码中明显无法访问的语句(如 return , throw , break 或者continue语句 ,以及一些不是函数/变量的的声明)。通过这个选项可以禁用掉这个优化功能。
-nc or --no-copyright — 默认情况下,uglifyjs将在生成的代码中保留初始的一些标记(假设版权信息等)。如果你设置这个参数将被禁止。
-o filename or --output filename — 将结果输出到一个指定文件名的文件中。如果没有这个参数,结果将会被输出到命令行
-
-overwrite — 如果代码是从一个文件中读取的(不是直接标准输入的)并且使用了--overwrite参数,那么结果也将会被写进相同的文件中去。
--ast — pass this if you want to get the Abstract Syntax Tree instead of JavaScript as output. Useful for debugging or learning more about the internals.
--ast — pass 如果你要获取一个用来取代javascript输出的抽象语法树,这些参数会在你进行调试或学习内部组件时很有用。
-v or --verbose — output some notes on STDERR (for now just how long each operation takes).
-v or --verbose — output 一些标准错误提示(显示每一次花费多久)
--extra — enable additional optimizations that have not yet been extensively tested. These might, or might not, break your code. If you find a bug using this option, please report a test case.
当你发现BUG时你可以增加一个中断点用来对还没有彻底的测试的代码进行优化,你可以使用这个选项来生成一个测试用例。
--extra — enable
--unsafe — enable other additional optimizations that are known to be unsafe in some contrived situations, but could still be generally useful. For now only this:
foo.toString() ==> foo+””
想foo.toString() 这种用法 也是可行的,但是存在一些人為的不安全的情况,这事也需要添加一些优化比如: foo+””
--max-line-len (default 32K characters) — add a newline after around 32K characters. I’ve seen both FF and Chrome croak when all the code was on a single line of around 670K. Pass –max-line-len 0 to disable this safety feature.
在超过大概32K字节的时候你要增加一行,我有发现过在火狐和chorme下档代码一行超过670K的时候它会发出报警声。通过–max-line-len 0 去静止这个安全属性
--reserved-names — some libraries rely on certain names to be used, as pointed out in issue #92 and #81, so this option allow you to exclude such names from the mangler. For example, to keep names require and $super intact you’d specify –reserved-names “require,$super”.
--reserved-names — 些类库会依赖于特定的名称去使用,比如:#92 和#81 所以这个选项允许你去排除一些关键字。
下面说说的我的劳动成果。
UglifyJS在他的官网上下载的 mishoo-UglifyJS-v1.0.1-3-g0fa93d2.zip不能在windows下执行,那是在linux下执行。有此感到很郁闷都说好自己不能亲自试试,于是就在google上查找他的资料。
终于找到了可以使用java执行的UglifyJS的库。
https://github.com/yuanyan/UglifyJS-java上下载了yuanyan-UglifyJS-java-c530baf.zip解压后发现里面根本没有他的ReadMe里面所说的UglifyJS-java.jar文件,但是他给了所有的java的源文件。
不知道为什么?因为有很多不用java开发也用jQuery开始程序的兄弟们编译起来很费劲,我编译了一个请各位小菜们使用,UglifyJS-java原作者不要有什么想法,假如有请通知我,我会在我的资源中删除。
UglifyJS.jar 下载地址我的资源中查找或者下面的地址
http://download.csdn.net/source/3173876
注意:UglifyJS-java必须运行在jre 1.6以上
下面是UglifyJS的使用选项 下面的内容摘自网上,
非常感谢作者http://www.tanbo.name/a/js_jquery/20110330/118.html
uglifyjs [ 选项... ] [ 文件 ]
文件参数应该放在选项后面,uglifyjs 会读取文件中的javascript代码进行处理。
如果你不指定输出的文件名,那么他会把处理后的内容输出到命令行中。
例: uglifyjs 1.js 2.js 会创建一个 2.js 文件把 1.js处理完毕的内容输入到这里
例: uglifyjs 1.js 会读取1.js内容,并把结果输出到命令行中。
支持的选项:
-b or --beautify — 参数 -b 或者 --beautify 用于美化(格式化)代码。美化之前会压缩代码(未验证。)
-i N or --indent N — 缩进级别空格数
例:uglifyjs -b 1.js 2.js 会把1.js的内容格式后输出到2.js
-q or --quote-keys — quote keys in literal objects (by default, only keys that cannot be identifier names will be quotes).
-nm or --no-mangle — 变量名不缩短,意味着不会把代码的变量名缩短为 abcdefg
-ns or --no-squeeze — 不使用ast_squeeze()(可以使各种优化之后的代码更小,更具有可读性。)
-mt or --mangle-toplevel — mangle names in the toplevel scope too (by default we don’t do this).
--no-seqs — 当ast_squeeze()被调用的时候(除非你添加了--no-squeeze 参数才不会被调用)它将减少在一个代码块中重复声明的行。例如:“a = 10; b = 20; foo();”将被重写为“a=10,b=20,foo();”。在各种场合,这将允许我们丢弃代码块中的括号(在一些语句块变成一个独立的声明行之后)。这是默认的,因为经我们测试,它似乎更安全并且能节省几百bytes,但加上--no-seqs 后将被禁止。
--no-dead-code — 默认情况下,UglifyJS将会删除代码中明显无法访问的语句(如 return , throw , break 或者continue语句 ,以及一些不是函数/变量的的声明)。通过这个选项可以禁用掉这个优化功能。
-nc or --no-copyright — 默认情况下,uglifyjs将在生成的代码中保留初始的一些标记(假设版权信息等)。如果你设置这个参数将被禁止。
-o filename or --output filename — 将结果输出到一个指定文件名的文件中。如果没有这个参数,结果将会被输出到命令行
-
-overwrite — 如果代码是从一个文件中读取的(不是直接标准输入的)并且使用了--overwrite参数,那么结果也将会被写进相同的文件中去。
--ast — pass this if you want to get the Abstract Syntax Tree instead of JavaScript as output. Useful for debugging or learning more about the internals.
--ast — pass 如果你要获取一个用来取代javascript输出的抽象语法树,这些参数会在你进行调试或学习内部组件时很有用。
-v or --verbose — output some notes on STDERR (for now just how long each operation takes).
-v or --verbose — output 一些标准错误提示(显示每一次花费多久)
--extra — enable additional optimizations that have not yet been extensively tested. These might, or might not, break your code. If you find a bug using this option, please report a test case.
当你发现BUG时你可以增加一个中断点用来对还没有彻底的测试的代码进行优化,你可以使用这个选项来生成一个测试用例。
--extra — enable
--unsafe — enable other additional optimizations that are known to be unsafe in some contrived situations, but could still be generally useful. For now only this:
foo.toString() ==> foo+””
想foo.toString() 这种用法 也是可行的,但是存在一些人為的不安全的情况,这事也需要添加一些优化比如: foo+””
--max-line-len (default 32K characters) — add a newline after around 32K characters. I’ve seen both FF and Chrome croak when all the code was on a single line of around 670K. Pass –max-line-len 0 to disable this safety feature.
在超过大概32K字节的时候你要增加一行,我有发现过在火狐和chorme下档代码一行超过670K的时候它会发出报警声。通过–max-line-len 0 去静止这个安全属性
--reserved-names — some libraries rely on certain names to be used, as pointed out in issue #92 and #81, so this option allow you to exclude such names from the mangler. For example, to keep names require and $super intact you’d specify –reserved-names “require,$super”.
--reserved-names — 些类库会依赖于特定的名称去使用,比如:#92 和#81 所以这个选项允许你去排除一些关键字。
相关文章推荐
- JavaScript的js文件压缩和格式化工具
- JavaScript 代码美化 压缩 解压工具
- 9最好的JavaScript压缩工具
- 几款极品的javascript压缩混淆工具javascript
- javascript 代码优化工具 UglifyJS
- JAWR【一个java项目的javascript和CSS集成和压缩工具】
- HTML/CSS/Javascript代码在线压缩、格式化(美化)工具
- javascript压缩工具:YUI compressor
- 好用的压缩Javascript, CSS工具
- Javascript工具 - 完成JavaScript压缩和模糊处理
- UglifyJS--javascript代码压缩使用指南{转}
- javascript 在线压缩和解压工具
- JavaScript的js文件压缩和格式化工具
- [转]Javascript压缩工具
- JavaScript 代码压缩工具
- HTML/CSS/Javascript代码在线压缩、格式化(美化)工具
- HTML/CSS/Javascript代码在线压缩、格式化(美化)工具
- 几款极品的javascript压缩混淆工具
- Javascript代码压缩工具
- JavaScript 实现的 zip 压缩和解压缩工具包Zip.js使用详解