我在控制台上收到此JavaScript错误:
Uncaught SyntaxError:意外的令牌非法
这是我的代码:
var foo = 'bar';
如您所见,它非常简单。它怎么会引起语法错误?
我在控制台上收到此JavaScript错误:
Uncaught SyntaxError:意外的令牌非法
这是我的代码:
var foo = 'bar';
如您所见,它非常简单。它怎么会引起语法错误?
Answers:
当JavaScript解释器解析代码时,它将分成称为“令牌”的部分。当令牌不能分类为四种基本令牌类型之一时,在大多数实现中它将被标记为“ ILLEGAL”,并且会引发此错误。
例如,如果您尝试运行带有流氓@
字符,错放的花括号,括号,“智能引号”,未正确括起来的单引号(例如this.run('dev1)
)等js文件,则会引发相同的错误。
很多不同的情况都可能导致此错误。但是,如果您没有明显的语法错误或非法字符,则可能是由看不见的非法字符引起的。这就是答案。
分号后的代码中有一个不可见的字符。这是Unicode U+200B
零宽度空格字符(又名ZWSP
HTML实体​
)。已知该字符会导致Unexpected token ILLEGAL
JavaScript语法错误。
我不能确定,但是我的赌注是jsfiddle。如果从那里粘贴代码,则很可能包含一个或多个U+200B
字符。看来该工具使用该字符来控制长字符串的自动换行。
更新2013-01-07
在最新的jsfiddle更新之后,它现在像codepen一样将字符显示为红点。显然,它也不再
U+200B
自己插入字符,因此从现在开始此问题应该较少出现。更新2015-03-17
由于VirtualBox中的错误,Vagrant有时也会引起此问题。根据此博客文章的解决方案是
sendfile off;
在您的nginx配置中设置,或者EnableSendfile Off
使用Apache。
据报道,从Chrome开发人员工具粘贴的代码可能包含该字符,但是我无法在当前版本(OSX上为22.0.1229.79)上重现该字符。
角色是不可见的,我们怎么知道它在那里?您可以要求编辑器显示不可见的字符。大多数文本编辑器都具有此功能。例如,Vim默认情况下显示它们,并且ZWSP
显示为<u200b>
。您也可以在线调试它:jsbin在其代码窗格上将字符显示为红点(但在保存并重新加载页面后似乎将其删除)。CodePen.io还将其显示为点,并且即使保存后也将其保留。
这个角色还不错,实际上很有用。Wikipedia上的此示例演示了如何将其用于控制将长字符串包装到下一行的位置。但是,如果您不知道标记中字符的存在,则可能会出现问题。如果您将其包含在字符串中(例如,nodeValue
没有可见内容的DOM元素的内部),则可能期望该字符串为空,而实际上却不是(即使应用后也是如此String.trim
)。
ZWSP
也可能导致多余的空格显示在HTML页面上,例如,当在两个<div>
元素之间找到空白时(如在此问题上所见)。这种情况在jsfiddle上甚至无法重现,因为在此字符被忽略。
另一个潜在的问题:如果网页的编码未被识别为UTF-8,则实际上可能会显示该字符(例如,​
在latin1中)。
如果ZWSP
CSS代码(内联代码或外部样式表)上存在样式,则样式也无法正确解析,因此某些样式无法应用(如在此问题上所见)。
在ECMAScript规范(版本3和5.1)中,我找不到任何提及该特定字符的内容。当前版本在第7.1节中提到了相似的字符(U+200C
和U+200D
),该字符表示“在注释,字符串文字和正则表达式文字之外” 时应将它们视为s。例如,这些字符可能是变量名的一部分(并且确实有效)。IdentifierPart
var x\u200c;
第7.2节列出了有效的空格字符(例如制表符,空格,不间断空格等),并隐约提及任何其他Unicode“空格分隔符”(类别“ Zs”)都应视为空格。我可能不是讨论这方面规范的最佳人选,但在我看来,U+200B
应该根据实际情况将其视为空白,而实际上,实现(至少是Chrome和Firefox)似乎将它们视为意外情况。令牌(或其中一部分),导致语法错误。
为什么要在代码中寻找这个问题?即使被复制粘贴。
如果您看到了,将文件保存在同步文件夹中后到底发生了什么-您会*****
在文件末尾看到类似的信息。它根本与您的代码无关。
解。
如果您nginx
在“无业游民”框中使用-添加到服务器配置中:
sendfile off;
如果您apache
在“无业游民”框中使用-添加到服务器配置中:
EnableSendfile Off;
问题源:VirtualBox错误
当我在错误所指向的行之后有一个未终止的字符串时,在chrome中出现了此错误。关闭字符串后,错误消失了。
错误示例:
var file = files[i]; // SyntaxError: Unexpected token ILLEGAL
jQuery('#someDiv').innerHTML = file.name + " (" + formatSize(file.size) + ") "
+ "<a href=\"javascript: something('"+file.id+');\">Error is here</a>";
示例无错误:
var file = files[i]; // No error
jQuery('#someDiv').innerHTML = file.name + " (" + formatSize(file.size) + ") "
+ "<a href=\"javascript: something('"+file.id+"');\">Error was here</a>";
在运行OS X时,如果文件系统位于不支持HFS +的硬盘驱动器上,则文件系统会创建几乎所有文件的隐藏分支。有时(这在我现在刚刚发生)可能导致您的JavaScript引擎尝试运行数据叉而不是您打算运行的代码。发生这种情况时,您还将收到
SyntaxError: Unexpected token ILLEGAL
因为您文件的数据分支将包含Unicode U + 200B字符。删除数据分支文件将使您的脚本运行您的实际预期代码,而不是代码的二进制数据分支。
。无论如何:这些文件是在本身不支持完整HFS文件特征的卷上创建的(例如ufs卷,Windows文件共享等)。将Mac文件复制到这样的卷时,其数据派生存储在文件的常规名称下,其他HFS信息(资源派生,类型和创建者代码等)存储在第二个文件中(AppleDouble格式),名称以“。 ” 开头。(就OS-X而言,这些文件当然是不可见的,但对于其他OS而言则不可见;这有时可能会令人讨厌...)
我遇到了同样的问题,它的发生是因为我在文本字符串中添加代码时按下了回车键。
因为这是一个很长的文本字符串,所以我想查看所有内容而不必在文本编辑器中滚动,但是按回车键会在字符串中添加一个不可见的字符,这是非法的。我使用Sublime Text作为编辑器。