satan 通过 Google 阅读器发送给您的内容:
于 12-5-23 通过 酷壳 - CoolShell.cn 作者:陈皓
MelonCard发布了一篇文章——"how one missing var ruined our launch"("少写了一个var毁了我的网站"),这篇文章是说MelonCard用Node.js做后台,因为出了一个小高峰——有50-100人注册,结果整个网站都不响应了,而且还出现了很多奇怪的问题。当他们调查到问题的要源的时候,他们发现下面的代码少写了一个var。
app.all('/apps/:user_id/status', function(req, res, next) { // … initial = extractVariables(req.body); });
为什么inital少写一个var会引发这个问题呢?因为如果你不写var,这个局部的变量会被javascript当成全局变量,而这个变量又是一个函数,所以,当多用户并发的时候,这个本应该在不同用户下互不干扰的变量,成了各个用户共享的东西。试想,用户A的数据被用户B覆盖了,用户A和B的数据还没处理完,结果被新的C给搞乱了,程序的逻辑自然出现了问题。
在stackoverflow.com上有这么一个贴子说明了"有var"和"无var"的差别:
// These are both globals var foo = 1; bar = 2; function test() { var foo = 1; // Local bar = 2; // Global // Execute an anonymous function (function() { var wibble = 1; // Local foo = 2; // Inherits from scope above (creating a closure) moo = 3; // Global }()) }
上面这个示例告诉我们,如果你不用var,那么这个js引擎会一层一层地向上找父作用域中的变量,如果找到了,就用,如果找不到了,就会帮你定义一个全局的变量。上面这个例子充分说明了这一点。所以,如果你想在当前的作用域用声明变量,你一定要用var。这对于一些乱写javascript代码的程序员要注意了。这里再给大家介绍一个工具——
JSLint( http://www.jslint.com/ ),一个JS代码质量的分析工具,我们把上述stackoverflow的代码copy到JSLint这个在线工具中,我们可以看到下面的报告:
这个报告说明了源码中的那些变量的情况。
(全文完)
您可能也喜欢: | ||||
Javascript的两本书 | Javascript 曲线表作图库 | 把Flash转成Javascript/HTML5 | 理解Javascript的闭包 | 20个优秀的Javascript导航技术 |
无觅 |
相关文章
- 2012年03月07日 -- 理解Javascript的闭包
- 2012年02月27日 -- 再谈javascript面向对象编程
- 2012年01月09日 -- Javascript 面向对象编程
- 2011年12月07日 -- Web开发中需要了解的东西
- 2011年11月24日 -- 一些文章资源和趣闻
- 2011年10月31日 -- API设计:用流畅接口构造内部DSL
- 2011年08月15日 -- 对象的消息模型
可从此处完成的操作:
- 使用 Google 阅读器订阅酷壳 - CoolShell.cn
- 开始使用 Google 阅读器,轻松地与您喜爱的所有网站保持同步更新
没有评论:
发表评论