当我在chrome中运行我的页面时,我得到这个错误“uncaught syntaxerror unexpected token U”。在firefox中,我得到JSON。解析:意想不到的字符”。我从一个php文件返回json数据,返回的json字符串是有效的。我在http://jsonlint.com/上查过。任何帮助都将不胜感激。谢谢。

这是返回的JSON字符串

[
    ["1","Pan Africa Market","\"1521 1st Ave, Seattle, WA\"","47.608941","-122.340145","restaurant"],
    ["2","The Melting Pot","14 Mercer St, Seattle, WA","47.624562","-122.356442","restaurant"],
    ["3","Ipanema Grill","1225 1st Ave, Seattle, WA","47.606366","-122.337656","restaurant"],
    ["4","Sake House","230 1st Ave, Seattle, WA","47.612825","-122.34567","bar"],
    ["5","Crab Pot","1301 Alaskan Way, Seattle, WA","47.605961","-122.34036","restaurant"],
    ["6","Mexican Kitchen","2234 2nd Ave, Seattle,WA","47.613975","-122.345467","bar"],
    ["7","Wingdome","1416 E Olive Way, Seattle, WA","47.617215","-122.326584","bar"],
    ["8","Piroshky Piroshky","1908 Pike pl, Seattle, WA","47.610127","-122.342838","restaurant"]
]

当前回答

这种错误发生的最常见的情况是使用正在生成控件的模板,然后通过“覆盖”默认模板来更改id和/或name的生成方式

@Html.TextBoxFor(m => m, new {Name = ViewData["Name"], id = ViewData["UniqueId"]} )

然后忘记将ValidationMessageFor更改为

@Html.ValidationMessageFor(m => m, null, new { data_valmsg_for = ViewData["Name"] })    

希望这能为您节省一些时间。

其他回答

该错误通常在将值赋给JSON时出现。Parse实际上是未定义的。 所以,我会检查试图解析这个的代码——很可能你不是在解析这里显示的实际字符串。

JSON的参数。parse可能什么也不返回(即JSON的值)。解析未定义)!

它发生在我从xyz解析已编译的固体代码时。索尔文件。

import web3 from './web3';
import xyz from './build/xyz.json';

const i = new web3.eth.Contract(
  JSON.parse(xyz.interface),
  '0x99Fd6eFd4257645a34093E657f69150FEFf7CdF5'
);

export default i;

拼错了

JSON.parse(xyz.intereface)

什么也没回!

解决这个错误非常简单。

原因。 Javascript会给出这个错误,因为你解析的是空字符串、对象或数组。

决议 因此,要解决这个问题,只需检查您试图解析的字符串是否为空/null或不是。 如果不是空/null,可以解析该字符串。

let ParsedString;

if(yourString != null){
   ParsedString = JSON.parse(yourString);
}

您应该考虑尝试在服务器端解析数据,然后将其发送到客户端进行处理。

当我在for循环中对JSONArray运行find条件时,我遇到了这个错误。我遇到的问题是for循环中的一个值返回null的结果。因此,当我试图访问一个属性,它失败了。

因此,如果你在JSONArrays中做任何事情,你不确定数据源及其完整性,我认为在这种情况下处理null和未定义异常是一个好习惯。

我通过检查JSONArray上find的返回值是否为空并适当地处理异常来修复它。

我想这可能会有帮助。