你能在JSON对象中使用尾随逗号吗?

问题描述 投票:351回答:16

手动生成JSON对象或数组时,通常更容易在对象或数组中的最后一项上留下尾随逗号。例如,从字符串数组输出的代码可能看起来像(在像C ++一样的伪代码中):

s.append("[");
for (i = 0; i < 5; ++i) {
    s.appendF("\"%d\",", i);
}
s.append("]");

给你一个字符串

[0,1,2,3,4,5,]

这是允许的吗?

json syntax delimiter
16个回答
225
投票

不幸的是the JSON specification不允许使用尾随逗号。有一些浏览器允许它,但通常你需要担心所有的浏览器。

一般情况下,我尝试解决问题,并在实际值之前添加逗号,因此最终得到的代码如下所示:

s.append("[");
for (i = 0; i < 5; ++i) {
  if (i) s.append(","); // add the comma only if this isn't the first entry
  s.appendF("\"%d\"", i);
}
s.append("]");

for循环中额外的一行代码并不昂贵......

我在从某个表单的字典输出结构到JSON时使用的另一个替代方法是在每个条目之后总是附加一个逗号(如上所述),然后在末尾添加一个没有尾随逗号的虚拟条目(但是那只是懒惰; - >)。

不幸的是,对阵列不适用。


1
投票

根据我过去的经验,我发现不同的浏览器以不同的方式处理JSON中的尾随逗号。

Firefox和Chrome都处理得很好。但IE(所有版本)似乎打破了。我的意思是真的打破并停止阅读剧本的其余部分。

考虑到这一点,以及编写兼容代码总是很好的事实,我建议花费额外的努力来确保没有尾随逗号。

:)


1
投票

我保留当前计数并将其与总计数进行比较。如果当前计数小于总计数,则显示逗号。

如果在执行JSON生成之前没有总计数,则可能无法工作。

然后,如果您使用PHP 5.2.0或更高版本,您可以使用内置的JSON API格式化您的响应。


1
投票

使用Relaxed JSON,您可以使用尾随逗号,或者只留下逗号。它们是可选的。

没有理由需要出现所有逗号来解析类似JSON的文档。

看一下Relaxed JSON规范,您将看到原始JSON规范的“嘈杂”程度。太多的逗号和引号......

http://www.relaxedjson.org

您还可以使用此在线RJSON解析器尝试您的示例,并查看它是否正确解析。

http://www.relaxedjson.org/docs/converter.html?source=%5B0%2C1%2C2%2C3%2C4%2C5%2C%5D


0
投票

我通常遍历数组并在字符串中的每个条目后附加逗号。在循环之后,我再次删除最后一个逗号。

也许不是最好的方法,但比每次检查更便宜,如果它是循环中的最后一个对象我猜。


0
投票

不建议这样做,但你仍然可以做这样的事情来解析它。

jsonStr = '[0,1,2,3,4,5,]';
let data;
eval('data = ' + jsonStr);
console.log(data)

0
投票

有一种方法可以避免循环中的if-branch。

s.append("[ "); // there is a space after the left bracket
for (i = 0; i < 5; ++i) {
  s.appendF("\"%d\",", i); // always add comma
}
s.back() = ']'; // modify last comma (or the space) to right bracket

0
投票

由于for循环用于迭代数组或类似的可迭代数据结构,我们可以使用数组的长度,如图所示,

awk -v header="FirstName,LastName,DOB" '
  BEGIN {
    FS = ",";
    print("[");
    columns = split(header, column_names, ",");
  }
  { print("  {");
    for (i = 1; i < columns; i++) {
      printf("    \"%s\":\"%s\",\n", column_names[i], $(i));
    }
    printf("    \"%s\":\"%s\"\n", column_names[i], $(i));
    print("  }");
  }
  END { print("]"); } ' datafile.txt

使用datafile.txt,

 Angela,Baker,2010-05-23
 Betty,Crockett,1990-12-07
 David,Done,2003-10-31

127
投票

不会。在http://json.org维护的JSON规范不允许使用尾随逗号。从我所看到的,一些解析器可能在读取JSON字符串时默默地允许它们,而其他解析器会抛出错误。对于互操作性,您不应包含它。

上面的代码可以重新构造,要么在添加数组终止符时删除尾随逗号,要么在项目之前添加逗号,跳过第一个代码。


101
投票

简单,便宜,易于阅读,无论规格如何,始终可以使用。

$delimiter = '';
for ....  {
    print $delimiter.$whatever
    $delimiter = ',';
}

$ delim的冗余分配是一个非常小的代价。如果没有显式循环但是单独的代码片段,也可以正常工作。


19
投票

JavaScript中允许使用尾随逗号,但在IE中不起作用。道格拉斯克罗克福德的无版本JSON规范不允许它们,因为它是无版本的,所以不应该改变。 ES5 JSON规范允许它们作为扩展,但Crockford的RFC 4627没有,ES5恢复禁止它们。 Firefox紧随其后。 Internet Explorer是我们不能拥有好东西的原因。


13
投票

PHP编码器可能想要检查implode()。这需要一个数组使用字符串连接它。

来自docs ......

$array = array('lastname', 'email', 'phone');
echo implode(",", $array); // lastname,email,phone

13
投票

正如已经说过的那样,JSON规范(基于ECMAScript 3)不允许使用尾随逗号。 ES> = 5允许它,因此您可以在纯JS中实际使用该表示法。有争议,有些解析器确实支持它(http://bolinfest.com/essays/json.htmlhttp://whereswalden.com/2010/09/08/spidermonkey-json-change-trailing-commas-no-longer-accepted/),但它的规范(如http://json.org/所示)它不应该在JSON中工作。那件事说......

...我想知道为什么没有人指出你实际上可以在第0次迭代时拆分循环并使用前导逗号而不是尾随逗号来摆脱比较代码气味和循环中的任何实际性能开销,从而导致实际上比其他解决方案更短,更简单,更快(由于循环中没有分支/条件)的代码。

例如。 (在类似于OP提议的代码的C风格伪代码中):

s.append("[");
// MAX == 5 here. if it's constant, you can inline it below and get rid of the comparison
if ( MAX > 0 ) {
    s.appendF("\"%d\"", 0); // 0-th iteration
    for( int i = 1; i < MAX; ++i ) {
        s.appendF(",\"%d\"", i); // i-th iteration
    }
}
s.append("]");

7
投票

有趣的是,C&C ++(我认为C#,但我不确定)特别允许尾随逗号 - 正是由于给出的原因:它使程序化生成列表变得更加容易。不确定为什么JavaScript没有跟随他们的领先优势。


4
投票

使用JSON5。不要使用JSON。

  • 对象和数组可以包含尾随逗号
  • 如果对象键是有效标识符,则可以不加引号
  • 字符串可以单引号
  • 字符串可以分为多行
  • 数字可以是十六进制(基数为16)
  • 数字可以以(前导或尾随)小数点开头或结尾。
  • 数字可以包括Infinity和-Infinity。
  • 数字可以以明确的加号(+)开头。
  • 允许内联(单行)和块(多行)注释。

http://json5.org/

https://github.com/aseemk/json5


2
投票

根据Class JSONArray specification

  • 额外的(逗号)可能出现在结束括号之前。
  • 当存在(逗号)省略时,将插入空值。

所以,据我所知,应该允许写:

[0,1,2,3,4,5,]

但是可能会发生一些解析器将7作为项目计数(如Daniel Earwicker指出的IE8)而不是预期的6。


编辑:

我发现这个JSON Validator验证了针对RFC 4627(JavaScript Object Notation的应用程序/ json媒体类型)和JavaScript语言规范的JSON字符串。实际上,这里一个带有尾随逗号的数组被认为仅适用于JavaScript而不适用于RFC 4627规范。

但是,在RFC 4627规范中声明:

2.3。数组

数组结构表示为围绕零个或多个值(或元素)的方括号。元素以逗号分隔。

array = begin-array [ value *( value-separator value ) ] end-array

对我而言,这又是一个解释问题。如果你写的元素是用逗号分隔的(没有说明特殊情况,比如最后一个元素),可以用两种方式理解它。

附: RFC 4627不是标准(如明确说明的那样),并且已经被RFC 7159(这是一个提议的标准)所取代,RFC 7159

© www.soinside.com 2019 - 2024. All rights reserved.