分类
js

JS加分号的理由

JavaScript界关于是否应该加分号的争论由来已久。在我看来,这就跟《格利佛游记》中“大头党”、“小头党”一样,纯粹蛋疼,一群衣食无忧的达人,领着一群不明所以的小白战来战去。

吐槽时间结束。我本来对于分号不是很在意,一般每行都加,函数和条件后面不加。后来学会了“模块化”的写法——即每个逻辑用一个立即执行函数——(function () { // 逻辑主体 })()包裹,就开始混用。一直没遇到什么问题,直到今天是 Ant + Closure Compiler 编译部署肉大师,莫名其妙的挂掉了。排查半天发现是分号的问题。

原来的代码可能是这个样子:

// 模块1
// 前面有若干代码
var Manager = {
  prop: '',
  method: function () {

  }
}

// 模块2,开头是个立即执行函数
(function () {
  // 代码
})()<

经过压缩后变成这个样子:

// }}(function 那里,会被当成一个函数来执行,于是整体的解析就会出错了
var Manager = {prop: '',method: function () { // code }}(function () {// 代码})()

这时只要给每个文件的末尾加上分号,就解决了。还有种做法,就是在开头加上分号,很多开源代码也是这样做的:

;(function () {
  // code
})()

如此,便给JavaScript代码写分号添了一个理由。

分类
前端

使用Ant编译Web应用

开发只是万里长征走完前半截,测试部署也是很重要的环节。

尤其是,前端面临着两个很大的问题:

  1. 前端代码是开放的,用户随时可以直接读代码
  2. 代码下载到用户电脑上运行,需要占用带宽

所以如果我们可以先压缩、混淆代码,再部署给用户使用,就可以大大改善这种情况。这个时候,ant是不二的选择(因为我只会ant……)。

关于Ant

下载:http://ant.apache.org/bindownload.cgi

手册:http://ant.apache.org/manual/index.html