gpt4 book ai didi

javascript - 无效的 JSON 解析器错误

转载 作者:行者123 更新时间:2023-11-28 20:31:42 24 4
gpt4 key购买 nike

我有一个对象,其属性包含 quote(')、斜线 (/) 或 Environmental.NewLine

我将此对象构造为 JSON 字符串,并尝试将其分配给 jQGrid。

但它显示无效的 JSON 解析器错误

我怎样才能成功解析这个。

 myObj=new {Text=@"Samp'le value"}

在 ASP.Net MVC 中,return JSON(myObj) 用于构造 JSON。

有谁知道我们需要在哪里配置来处理这个 ' / Environmental.NewLine(\n) 在解析时JSON?

我们需要使用任何其他库来处理像 Newtosoft JSON

来自服务器的 JSON

     {"total":1 ,"page":1,"records":3,"rows":[{"i":0,"cell":"","1","1","DesSinglApostropAndURLhasEnterKeyChar",
"Samp'le value","http://google.com/Dashboard.aspx?ParcelNbr= {SITE_APN}","False","",""]},"i":1,"cell":"","2","2","DesWithSlashAndURLwithSlash",
"Sample\value2","http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=\XYZ","False","",""]},{"i":2,"cell":["","3","3","DesWithAmpersand","Sample & value3"","http://Googole.com","False","",""]}]}

最佳答案

对应于规范(参见 herehere ),只有 "\ 字符必须转义。其他一些字符 < em>可能被转义。所以未转义的'字符不是错误。我认为错误“无效的JSON解析器错误”还有另一个原因。

您应该包含更完整的 JavaScript 代码(显示如何使用 jqGrid)、ASP.NET MVC Controller 操作的代码或更完整的返回服务器的 JSON 响应。一般来说,您可以生成正确的 JSON 响应,而无需 Json.NET (Newtosoft) 或与它或任何其他库一起使用。

您应该包含 autoencode: true 选项以在 jqGrid 中正确显示任何文本数据。您应该使用 datatype: "json"jsonReader 选项(请参阅 the documentation )。因此,仅仅生成格式良好的 JSON 或 XML 数据以在 jqGrid 中正确显示数据是不够的。可能需要包含 jqGrid 选项,该选项提供有关数据的确切格式的信息。

已更新:您发布的 JSON 数据确实已损坏。 jsonlint.org是验证 JSON 数据的好地方。也许您尝试手动生成 JSON 数据,因为数据绝对错误:

{
"total": 1,
"page": 1,
"records": 3,
"rows": [
{
"i": 0,
"cell": "", <---- it must be "cell": [""
"1",
"1",
"DesSinglApostropAndURLhasEnterKeyChar",
"Samp'le value",
"http://google.com/Dashboard.aspx?ParcelNbr= {SITE_APN}",
"False",
"",
""
]
},
"i": 1, <--- it must be {"i": 1
"cell": "",
"2",
"2",
"DesWithSlashAndURLwithSlash",
"Sample\value2", <--- it must be "Sample\\value2" or "Sample value2"
"http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=\XYZ", <--- \XYZ is WRONG
"False",
"",
""
]
},
{
"i": 2,
"cell": [
"",
"3",
"3",
"DesWithAmpersand",
"Sample & value3"","http: //Googole.com","False","",""]}]} <-- "Sample & value3"" is WRONG

数据包含 5 个语法错误:

  • 使用 "cell": "" 代替 "cell": [""
  • 使用 }, "i": 1, 代替 }, {"i": 1,
  • 使用“Sample\value2”而不是“Sample value2”“Sample\\value2”
  • 使用 "http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=\XYZ" 而不是 "http://Googole.com/Dashboard .aspx?ParcelNbr={SITE_APN}&ABC=XYZ""http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=\\XYZ"<
  • 使用“Sample & value3””,而不是“Sample & value3”“Sample & value3\””

此外,您使用了 i 属性而不是 id ("i": 1 必须固定为 "id": 1 )。这不是 JSON 中的错误,但您应该为 jqGrid 生成数据,因此您应该保留 jqGrid 期望的格式。请参阅the documentation 。固定的 JSON 响应应该类似于

{
"total": 1,
"page": 1,
"records": 3,
"rows": [
{
"id": 0,
"cell": [
"",
"1",
"1",
"DesSinglApostropAndURLhasEnterKeyChar",
"Samp'le value",
"http://google.com/Dashboard.aspx?ParcelNbr= {SITE_APN}",
"False",
"",
""
]
},
{
"id": 1,
"cell": [
"",
"2",
"2",
"DesWithSlashAndURLwithSlash",
"Sample value2",
"http://Googole.com/Dashboard.aspx?ParcelNbr={SITE_APN}&ABC=XYZ",
"False",
"",
""
]
},
{
"id": 2,
"cell": [
"",
"3",
"3",
"DesWithAmpersand",
"Sample & value3",
"http: //Googole.com",
"False",
"",
""
]
}
]
}

我建议您分析使用 jqGrid 的 ASP.NET MVC 示例的代码(例如,请参见here)并修复您的服务器代码。

关于javascript - 无效的 JSON 解析器错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16228490/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com