怎样用yuicompressor压缩使用了seajs架构的js代码?

yuicompressor会替换本地变量名
于是require就被替换了掉了,但是http://seajs.org/docs/zh-cn/rules.htm...
seajs要求require不被替换

yuicompressor好像不能为单独的变量加一个特殊规则
但要为了一个require不压缩所有的本地变量又觉得不划算呀。

阅读 8.6k
5 个回答

spm已经支持了局部压缩,假设 a -> b -> c -> d

spm build c.js

则仅仅会合并c和d,而spm还提供有同步和异步两种方案进行require

仔细想了下,鉴于你的需求,我比较倾向于这样处理:

a 里面 require('b')
b 里面 require.async('c')
c 里面 require('d')

这样spm build的时候可以分开两步:

spm build a.js
spm build c.js

这样可以打包为两个文件,因为这种局部打包其实说到最后还是怎么界定优化策略的问题,spm无法做得太多(或许还是不够聪明),但是因为seajs利用正则把require变成异步的方案仅推荐在开发的时候用,正式上线的时候还是区分开异步(require.async)和同步比较好。

我顺手做了个DEMO,https://gist.github.com/2583839 不知道这样做能否解决你的问题?

建议用 spm 来打包

新手上路,请多包涵

修改源码
util.parseDependencies = function(code) {
var ret = [], match, regRequire,
regGet = /^function\s*\(\s*(\w+)/;

code = removeComments(code);

match = regGet.exec(code);
regRequire = new RegExp('(?:^|[^.$])\\b' + match[1] + '\\s*\\(\\s*([\"\'])([^\"\'\\s\)]+)\\1\\s*\\)', 'g');

regRequire.lastIndex = 0;

while ((match = regRequire.exec(code))) {
if (match[2]) {
ret.push(match[2])
}
}

return util.unique(ret)
}

新手上路,请多包涵

可以使用UglifyJS进行压缩:

UglifyJS hello.js -o hello.min.js -c -m -r require
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题