我最近注意到网络上的很多JavaScript文件都是在评论部分后紧跟;
开头的。
例如,this jQuery plugin's代码以:
开头/**
* jQuery.ScrollTo
* Copyright (c) 2007-2008 Ariel Flesler - aflesler(at)gmail(dot)com | http://flesler.blogspot.com
* Dual licensed under MIT and GPL.
* Date: 9/11/2008
.... skipping several lines for brevity...
*
* @desc Scroll on both axes, to different values
* @example $('div').scrollTo( { top: 300, left:'+=200' }, { axis:'xy', offset:-20 } );
*/
;(function( $ ){
为什么文件需要以;
开头?我也在服务器端JavaScript文件中看到了这个约定。
这样做的优点和缺点是什么?
答案 0 :(得分:350)
我想说,因为脚本经常被连接和缩小/压缩/一起发送,所以最后一个人有可能有类似的东西:
return {
'var':'value'
}
在最后一个脚本的末尾没有;
。如果您在开始时有;
,那么它是安全的,例如:
return {
'var':'value'
}
;(function( $ ){ //Safe (still, screw you, last guy!)
return {
'var':'value'
}
(function( $ ){ //Oh crap, closure open, kaboom!
return {
'var':'value'
};
;(function( $ ){ //Extra ;, still safe, no harm
答案 1 :(得分:56)
我相信(虽然我不确定,所以请不要抨击我)这样可以确保关闭来自不同文件的任何先前声明。在最坏的情况下,这将是一个空语句,但在最好的情况下,当未完成的语句实际来自上面时,它可以避免尝试追踪此文件中的错误。
答案 2 :(得分:12)
考虑这个例子:
function a() {
/* this is my function a */
}
a()
(function() {
/* This is my closure */
})()
将会发生这样的评估:
function a() {
/* this is my function a */
}
a()(function() {})()
所以a
返回的内容将被视为一个试图初始化的函数。
这主要是为了防止在尝试将多个文件连接到一个文件时出错:
<强> a.js 强>
function a() {
/* this is my function a */
}
a()
<强> b.js 强>
(function() {
/* This is my closure */
})()
如果我们将这些文件连在一起会导致问题。
因此,请记住将;
放在(
前面,也可以放在其他一些地方。顺便说一句。 var a = 1;;;var b = 2;;;;;;;;;var c = a+b;
是完全有效的JavaScript