我在我的MooTools脚本中运行一个AJAX调用,这在Firefox中工作得很好,但在Chrome中,我得到了一个未捕获的SyntaxError:意外令牌:错误,我不能确定为什么。注释掉代码来确定坏代码在哪里不会产生任何结果,我认为这可能是JSON返回的问题。检查控制台,我看到返回的JSON是这样的:

{"votes":47,"totalvotes":90}

我没有看到它有任何问题,为什么会出现这个错误?

vote.each(function(e){
  e.set('send', {
    onRequest : function(){
      spinner.show();
    },
    onComplete : function(){
      spinner.hide();
    },
    onSuccess : function(resp){
      var j = JSON.decode(resp);
      if (!j) return false;
      var restaurant = e.getParent('.restaurant');
      restaurant.getElements('.votes')[0].set('html', j.votes + " vote(s)");
      $$('#restaurants .restaurant').pop().set('html', "Total Votes: " + j.totalvotes);
      buildRestaurantGraphs();
    }
  });

  e.addEvent('submit', function(e){
    e.stop();
    this.send();
  });
});

当前回答

听起来好像你的回答被评估了。这将在Chrome中给出相同的错误:

var resp = '{"votes":47,"totalvotes":90}';
eval(resp);

这是由于大括号的{…}被javascript解释为代码块,而不是人们可能期望的对象文字。

我会查看JSON.decode()函数,看看是否有一个eval在那里。

这里也有类似的问题: Eval() =意外令牌:错误

其他回答

未捕获的SyntaxError:意外的令牌}

Chrome给了我这个示例代码的错误:

<div class="file-square" onclick="window.location = " ?dir=zzz">
    <div class="square-icon"></div>
    <div class="square-text">zzz</div>
</div>

并解决了它,固定的onclick就像

... onclick="window.location = '?dir=zzz'" ...

但是这个错误和这个问题无关。

这个错误也可能意味着代码中缺少冒号或:。

虽然迟到了,但我的解决方案是将dataType指定为json。或者确保您没有设置jsonp: true。

对我来说,当我在Chrome浏览器中查看页面的源代码时,灯泡就亮了。我在if语句中多了一个括号。您将立即在失败的行上看到一个带叉的红圈。这是一个相当没有帮助的错误消息,因为“未捕获语法错误:意外令牌”第一次出现在Chrome控制台时没有引用行号。

听起来好像你的回答被评估了。这将在Chrome中给出相同的错误:

var resp = '{"votes":47,"totalvotes":90}';
eval(resp);

这是由于大括号的{…}被javascript解释为代码块,而不是人们可能期望的对象文字。

我会查看JSON.decode()函数,看看是否有一个eval在那里。

这里也有类似的问题: Eval() =意外令牌:错误