为什么JavaScript需要以“;”开头?

时间:2010-03-20 01:33:47

标签: javascript jquery jquery-plugins serverside-javascript

我最近注意到网络上的很多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文件中看到了这个约定。

这样做的优点和缺点是什么?

3 个答案:

答案 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