当前位置: 首页 > 面试题库 >

JSON.Parse,'未捕获的SyntaxError:意外令牌o

齐昊焱
2023-03-14
问题内容

我从网络服务返回的JSON遇到问题。看起来JSON缺少引号,但是当我在JSON中添加引号时,出现错误。这是错误消息:’Uncaught
SyntaxError:意外的标记o。当我将字符串记录到控制台时:[对象对象],[对象对象]

这是一些模拟错误的示例代码:

//Error I am trying to solve
var jsonString = '[{"Id":"10","Name":"Matt"},{"Id":"1","Name":"Rock"}]';
var myData = JSON.parse(jsonString);

$(document).ready(function() {
    var $grouplist = $('#groups');
    $.each(myData, function() {
        $('<li>' + this.Name + '</li>').appendTo($grouplist);
    });
});

这是相同的代码,在字符串两边用单引号引起来。有用

//Successful Javascript
var jsonString = '[{"Id":"10","Name":"Matt"},{"Id":"1","Name":"Rock"}]';
var myData = JSON.parse(jsonString);

$(document).ready(function() {
    var $grouplist = $('#groups');
    $.each(myData, function() {
        $('<li>' + this.Name + '</li>').appendTo($grouplist);
    });
});

//Successful HTML
<ul id="groups"></ul>

但是,当我尝试在字符串中添加引号时,就像我在实际代码中似乎需要的那样,它失败了:

//Does not work when I need to append quotes to the string:
var jsonStringNoQuotes = [{"Id":"10","Name":"Matt"},{"Id":"1","Name":"Rock"}];
jsonStringQuotes = "'" + jsonStringNoQuotes + "'";
var myData = JSON.parse(jsonStringQuotes);

$(document).ready(function() {
    var $grouplist = $('#groups');
    $.each(myData, function() {
        $('<li>' + this.Name + ',' +  this.Id + '</li>').appendTo($grouplist);
    });
});

这是错误:控制台的日志字符串:[对象对象],[对象对象] data.js:809未捕获的语法错误:意外的令牌’

我很沮丧 任何帮助表示赞赏!谢谢!


问题答案:

如果没有单引号,那么您正在创建一个数组,其中包含两个对象。这是JavaScript自己的语法。当您添加引号时,该对象(数组+
2个对象)现在是字符串。您可以JSON.parse用来将字符串转换为JavaScript对象。您不能用于JSON.parse将JavaScript对象转换为JavaScript对象。

//String - you can use JSON.parse on it
var jsonStringNoQuotes = '[{"Id":"10","Name":"Matt"},{"Id":"1","Name":"Rock"}]';

//Already a javascript object - you cannot use JSON.parse on it
var jsonStringNoQuotes = [{"Id":"10","Name":"Matt"},{"Id":"1","Name":"Rock"}];

此外,您的最后一个示例失败,因为您要在JSON字符串中添加文字单引号字符。这是非法的。JSON规范指出仅允许使用双引号。如果您要console.log遵循以下…

console.log("'"+[{"Id":"10","Name":"Matt"},{"Id":"1","Name":"Rock"}]+"'");
//Logs:
'[object Object],[object Object]'

您会看到它返回数组的字符串表示形式,该字符串表示形式转换为逗号分隔的列表,并且每个列表项都是对象的字符串表示形式,即[object Object]。请记住,JavaScript中的关联数组只是对象,每个键/值对都是一个属性/值。

为什么会这样?因为您是从字符串开始的"'",所以您尝试将数组追加到它的后面,该数组请求它的字符串表示形式,然后再追加另一个string "'"

请不要将JSON与Javascript混淆,因为它们是完全不同的东西。JSON是一种人类可读的数据格式,旨在与创建javascript对象时使用的语法匹配。JSON是一个字符串。Javascript对象不是,因此在代码中声明时不会用引号引起来。

看到这个小提琴:http :
//jsfiddle.net/NrnK5/



 类似资料:
  • 问题内容: 是什么导致第三行出现此错误? 打开控制台以查看错误 问题答案: 是一个对象。(从对象文字创建) 用于将包含JSON表示法的 字符串 转换为Javascript对象。 您的代码将对象转换为字符串(通过调用),以尝试将其解析为JSON文本。 默认返回,这是无效的JSON;因此错误。

  • 问题内容: 尝试传递以下字符串时出现语法错误: 我知道当我使用双引号时,错误来自链接。 如果我使用单引号,则没有问题,但是数据是从服务器端获取的,我无法控制要传入的内容,因此只能在我这一边进行控制。 到目前为止,我从互联网上阅读的内容尝试了以下操作: 先使用,然后再使用。我可以解析没有问题,但是当我尝试循环数据时会出现问题。循环不是将其作为JSON循环,而是将数据作为字符串并循环每个单个文本。 转

  • 问题内容: 我在MooTools脚本中运行AJAX调用,在Firefox中运行正常,但是在Chrome中出现错误,我无法确定原因。注释掉代码以确定错误代码在什么地方不会产生任何结果,我认为这可能与返回JSON有关。在控制台中检查,我看到返回的JSON是这样的: 我没有看到任何问题,为什么会发生此错误? 问题答案: 我刚刚解决了这个问题。导致标准Request调用出现问题的原因是,这是我改用的代码:

  • 问题内容: 我正在尝试开始在ReactJS中构建网站。但是,当我尝试将JS放在单独的文件中时,我开始收到此错误:“ Uncaught SyntaxError:Unexpected token <”。 我尝试添加到JS文件的顶部,但没有解决任何问题。以下是HTML和JS文件。关于出什么问题有什么想法吗? 的HTML JS 编辑:我意识到我需要添加到包括我的着陆器代码的脚本标签。但是,添加并重新加载后

  • 问题内容: 我正在尝试开始在ReactJS中构建网站。但是,当我尝试将JS放在单独的文件中时,我开始收到此错误:“ Uncaught SyntaxError:Unexpected token <”。 我尝试添加到JS文件的顶部,但没有解决任何问题。以下是HTML和JS文件。关于出什么问题有什么想法吗? HTML JS 编辑:我意识到我需要添加到包括我的着陆器代码的脚本标签。但是,添加并重新加载后,

  • 问题内容: 我是Web服务的新手。在我的项目中,当我尝试运行时,我连接了Web Service(一切就绪),现在出现以下错误。 错误-> Web服务和我的页面在相同的解决方案中,但项目不同。 相关代码如下: jQuery (URL:11761) 网络服务 (URL:12015) 在这里问之前,我已经通过了此链接(无法理解) 问题答案: 弄清了您违反了相同来源策略的原因,因为站点和Web服务正在两个