没有可见的原因导致“意外令牌非法”

2020/10/08 14:21 · javascript ·  · 0评论

我在控制台上收到此JavaScript错误:

Uncaught SyntaxError:意外的令牌非法

这是我的代码:

var foo = 'bar';​

如您所见,它非常简单。它怎么会引起语法错误?

错误

当JavaScript解释器解析代码时,它将分成称为“令牌”的部分。当令牌不能分类为四种基本令牌类型之一时,在大多数实现中它将被标记为“ ILLEGAL”,并且会引发此错误。

例如,如果您尝试运行带有流氓@字符,错放的花括号,括号,“智能引号”,未正确括起来的单引号(例如this.run('dev1))等js文件,则会引发相同的错误

许多不同的情况都可能导致此错误。但是,如果您没有明显的语法错误或非法字符,则可能是由看不见的非法字符引起的这就是答案。

但是我看不到任何非法的东西!

分号后的代码中有一个不可见的字符。这是UnicodeU+200B零宽度空格字符(又名ZWSPHTML实体​)。已知该字符会导致Unexpected token ILLEGALJavaScript语法错误。

它是从哪里来的?

我不能确定,但​​是我敢打赌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中)。

如果ZWSPCSS代码(内联代码或外部样式表)上存在样式,则也无法正确解析样式,因此某些样式无法应用(如在此问题上所见)。

ECMAScript规范

我在ECMAScript规范(版本35.1)中没有提到该特定字符当前版本第7.1节中提到了类似的字符(U+200CU+200D,该字符表示“在注释,字符串文字和正则表达式文字之外”时应将它们视为s。例如,这些字符可能是变量名的一部分(并且确实有效)。IdentifierPartvar x\u200c;

第7.2节列出了有效的空格字符(例如制表符,空格,不间断空格等),并隐约提及将任何其他Unicode“空格分隔符”(类别“ Zs”)都视为空格。我可能不是讨论这方面规范的最佳人选,但在我看来,U+200B应该这样认为是空白,而实际上,实现(至少是Chrome和Firefox)似乎将它们视为意外情况令牌(或其中一部分),导致语法错误。

为什么要在代码中寻找这个问题?即使被复制粘贴。

如果您看到了,将文件保存在同步文件夹中后究竟发生了什么-您将*****在文件末尾看到类似的内容。它根本与您的代码无关。

解。

如果您nginx在“无业游民”框中使用-添加到服务器配置中:

sendfile off;

如果您apache在“无业游民”框中使用-添加到服务器配置中:

EnableSendfile Off;

问题源:VirtualBox错误

如果要将代码从另一个文档(例如PDF)复制到控制台并尝试运行它,也可能会发生这种情况。

我试图从正在阅读的Javascript书中运行一些示例代码,但很惊讶它没有在控制台中运行。

显然,从PDF复制会在代码中引入一些意外的,非法的和不可见的字符。

我在Mac上遇到了同样的问题,发现这是因为Mac用卷曲的引号代替了标准引号,而卷曲的引号是非法的javascript字符。

为了解决这个问题,我不得不更改我的Mac系统偏好设置=>键盘=>文本(选项卡)上的设置,取消选中使用智能引号和破折号(选中了默认值)。

当我在错误所指向的行之后有一个未终止的字符串时,在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>";

如果您正在运行nginx + uwsgi安装程序,那么主要问题是一些答案中提到的带有发送文件的虚拟盒错误。但是要解决该问题,您必须在nginx和uwsgi中都禁用sendfile。

  1. 在nginx.conf中关闭sendfile

  2. uwsgi应用程序/配置--disable-sendfile

在运行OS X时,如果文件系统位于不支持HFS +的硬盘驱动器上,则文件系统会创建几乎所有文件的隐藏分支。有时(刚才发生在我身上)可能导致您的JavaScript引擎尝试运行数据叉而不是您打算运行的代码。发生这种情况时,您还将收到

SyntaxError: Unexpected token ILLEGAL

因为您文件的数据分支将包含Unicode U + 200B字符。删除数据分支文件将使您的脚本运行您的实际预期代码,而不是代码的二进制数据分支。

无论如何:这些文件是在本机不支持完整HFS文件特征的卷(例如ufs卷,Windows文件共享等)上创建的。将Mac文件复制到这样的卷时,其数据分支存储在文件的常规名称下,其他HFS信息(资源分支,类型和创建者代码等)存储在第二个文件中(AppleDouble格式),名称以“。开头(就OS-X而言,这些文件当然是不可见的,但对于其他OS而言则不可见;这有时可能会令人讨厌...)

这是我的原因:

之前:

var path = "D:\xxx\util.s"

\u是一个转义,我通过使用Codepen的分析JS来解决。

后:

var path = "D:\\xxx\\util.s"

和错误修复

我遇到了同样的问题,它的发生是因为我在文本字符串中添加代码时按了回车键。

因为它是一个很长的文本字符串,所以我想查看所有内容而不必在文本编辑器中滚动,但是按Enter键会在字符串中添加一个不可见的字符,这是非法的。我使用Sublime Text作为编辑器。

就像那样,我将所有空间区域都更改为&nbsp,并且工作正常。

val.replace(“”,“&nbsp”);

希望对您有所帮助。

我将再增加一个答案。也可能由于编码而发生此问题。您希望utf8编码是安全的。默认情况下,某些编辑器使用utf16,这可能会引起问题。一种快速的测试方法是,例如,在VS代码中,只需重新创建相同的内容,但使用vscode的本地编辑器即可创建文件。希望这会有所帮助。

本文地址:http://javascript.askforanswer.com/meiyoukejiandeyuanyindaozhiyiwailingpaifeifa.html
文章标签: ,   ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!