如何使用 Javascript 或 Jquery 将 JSON 对象包装在数组中?

Posted

技术标签:

【中文标题】如何使用 Javascript 或 Jquery 将 JSON 对象包装在数组中?【英文标题】:How can I wrap JSON objects in an array using Javascript or Jquery? 【发布时间】:2012-12-29 04:05:36 【问题描述】:

如何将此处的所有数据包装在一个数组中?这是从网站系统自动生成的,我输入它的应用程序需要将数据放在数组中。 JSON 中有多组数据,这只是大约 5 或 6 个中的 2 个。

collection: 
id: "5096f729e4b02d37bef658f2",
enabled: true,
starred: false,
type: 10,
ordering: 3,
title: "About",
navigationTitle: "About",
urlId: "about",
itemCount: 0,
updatedOn: 1347025745523,
publicCommentCount: 0,
folder: false,
dropdown: false,
tags: [ ],
categories: [ ],
homepage: true,
typeName: "page",
synchronizing: false,
typeLabel: "page",
fullUrl: "/"
,

websiteSettings: 
id: "5096f728e4b02d37bef658e0",
websiteId: "5096f728e4b02d37bef658df",
type: "Business",
subject: "Personal",
country: "US",
state: "NY",
markdownMode: false,
simpleLikingEnabled: true,
commerceEnabled: false,
defaultPostFormat: "%y/%m/%d/%t",
commentLikesAllowed: true,
commentAnonAllowed: true,
commentThreaded: true,
commentApprovalRequired: false,
commentAvatarsOn: true,
commentSortType: 2,
commentFlagThreshold: 0,
commentFlagsAllowed: true,
commentEnableByDefault: true,
commentDisableAfterDaysDefault: 0,
disqusShortname: "username",
homepageTitleFormat: "%s - This is a test",
collectionTitleFormat: "%c — %s - This is a test",
itemTitleFormat: "%i — %s - This is a test",
commentsEnabled: true,
allowSquarespacePromotion: false,
storeSettings: 
storeTitle: "Test",
returnPolicy: null,
termsOfService: null,
privacyPolicy: null,
stockLevelAlertLimit: 5,
useLightCart: false,
stripeConnected: false,
storeState: 3


【问题讨论】:

@Passerby:问题中没有提到 php 我们需要更多信息来回答问题。你想做什么。我的意思是,如果您只是想将它包装在一个数组中,只需在开头和结尾添加 [] ——您似乎已经拥有有效的 json 对象 对不起。因此,可以通过在 Squarespace 网站平台的页面上附加 ?format=json-pretty 来获得此 JSON 数据。示例:squarespace.com/?format=json-pretty 我需要在我的应用程序中使用 javascript 或 Jquery 将数据放入数组中,因为该应用程序只识别数组中的数据。 所以数据是作为对象属性给出的,其键是“collection”、“website”、“items”等。你想要一个只包含这些键的值的数组吗?跨度> 问题是它不是数组数据。它是带有键和值的数据。您当然可以创建一个仅包含值的数组,但是您的应用程序如何知道每个值的含义?您必须对每个数组位置的含义进行硬编码?或者你想要一个对象数组,其中每个对象都包含一个键和值? 【参考方案1】:

好的,假设您在名为rawJson 的变量中拥有从 API 返回的 JSON。这对你来说很容易用 jquery 来做,例如getJSON。现在你可以用这段代码实现你想要的了:

var rawJson = // get this yourself, pretend I'm inserting the JSON literal from the url you linked to above in your comments
arrayYouWant = [];

for (category in rawJson) 
  for (key in rawJson[category]) 
    arrayYouWant.push( key: rawJson[category][key] )
  

【讨论】:

【参考方案2】:

您也可以将这两个对象展平并将它们转换为数组,请参见下面的 sn-p。

var rawJSON = 
  collection: 
    id: "5096f729e4b02d37bef658f2",
    enabled: true,
    starred: false,
    type: 10,
    ordering: 3,
    title: "About",
    navigationTitle: "About",
    urlId: "about",
    itemCount: 0,
    updatedOn: 1347025745523,
    publicCommentCount: 0,
    folder: false,
    dropdown: false,
    tags: [],
    categories: [],
    homepage: true,
    typeName: "page",
    synchronizing: false,
    typeLabel: "page",
    fullUrl: "/"
  ,

  websiteSettings: 
    id: "5096f728e4b02d37bef658e0",
    websiteId: "5096f728e4b02d37bef658df",
    type: "Business",
    subject: "Personal",
    country: "US",
    state: "NY",
    markdownMode: false,
    simpleLikingEnabled: true,
    commerceEnabled: false,
    defaultPostFormat: "%y/%m/%d/%t",
    commentLikesAllowed: true,
    commentAnonAllowed: true,
    commentThreaded: true,
    commentApprovalRequired: false,
    commentAvatarsOn: true,
    commentSortType: 2,
    commentFlagThreshold: 0,
    commentFlagsAllowed: true,
    commentEnableByDefault: true,
    commentDisableAfterDaysDefault: 0,
    disqusShortname: "username",
    homepageTitleFormat: "%s - This is a test",
    collectionTitleFormat: "%c — %s - This is a test",
    itemTitleFormat: "%i — %s - This is a test",
    commentsEnabled: true,
    allowSquarespacePromotion: false,
    storeSettings: 
      storeTitle: "Test",
      returnPolicy: null,
      termsOfService: null,
      privacyPolicy: null,
      stockLevelAlertLimit: 5,
      useLightCart: false,
      stripeConnected: false,
      storeState: 3
    
  


var myObject = Object.assign(, rawJSON.collection); // merging objects aka extend
myObject = Object.assign(myObject, rawJSON.websiteSettings);

// a: 1, b: 2 => [['a', 1], ['b', 2]]
var objAsAnArray=Object.keys(myObject).map((k)=>[k, JSON.stringify(myObject[k])])

console.log(objAsAnArray)

【讨论】:

以上是关于如何使用 Javascript 或 Jquery 将 JSON 对象包装在数组中?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 JavaScript 或 jQuery 更改数组内对象的值?

如何使用 jquery 或 javascript 删除索引处的行? [复制]

如何使用 jQuery 或 JavaScript 设置底边距

如何使用 PHP 或 JavaScript/jQuery 禁用地址栏?

如何防止使用 jQuery 或 Javascript 进行双重提交?

当您使用 javascript 或 jquery 将鼠标悬停时,如何使图像或按钮发光?