我是JavaScript的新手,刚开始用JavaScript进行一些更严肃的开发.我有很多乐趣来实现Module模式.真正让我发疯的一件事是"回归"陈述的行为.如果你写的话,这是一个很大的不同
Test = ( function()
{
var message = "Hello World!";
return
{
// Does not work
printTest: function() { window.alert(message); }
};
}());
Run Code Online (Sandbox Code Playgroud)
要么
Test = ( function()
{
var message = "Hello World!";
return {
// Works well
printTest: function() { window.alert(message); }
};
}());
Run Code Online (Sandbox Code Playgroud)
请注意'return'语句后的花括号.
这是一个典型的愚蠢的菜鸟错误,并在某处有详细记录吗?
萤火虫无法给出一丝暗示.IE9和Chrome确实在代码的后面位置报告了一些模糊的语法错误:' function'statement in" printTest: function()" 之后的左括号.
对此有何评论?JavaScript中有更多这样的陷阱吗?
如果将括号放到下一行,则解释器会假定存在分号.
所以你的return语句将被解释为:
return;
{
printTest: function() { window.alert(message); };
}
Run Code Online (Sandbox Code Playgroud)
如果我记得很清楚,我会在JavaScript中解决这个问题:好的部分
JavaScript有一种机制,试图通过自动插入分号来纠正错误的程序.不要依赖于此.它可以掩盖更严重的错误.它有时会在不受欢迎的地方插入分号.考虑分号插入对return语句的影响.如果return语句返回一个值,那么该值表达式必须与返回的同一行开始:
return
{
status: true
};
Run Code Online (Sandbox Code Playgroud)
这似乎返回包含状态成员的对象.不幸的是,分号插入将其转换为返回undefined的语句.没有任何警告说分号插入导致了对程序的误解.如果{放在上一行的末尾而不是下一行的开头,则可以避免此问题:
return {
status: true
};
Run Code Online (Sandbox Code Playgroud)
"JavaScript:Douglas Crockford撰写的好文章.版权所有2008 Yahoo! Inc.,978-0-596-51774-8."
| 归档时间: |
|
| 查看次数: |
431 次 |
| 最近记录: |