将表单数据数组对象转换为 JSON

时间:2021-02-24 13:59:34

标签: html jquery node.js json

我正在尝试将表单数据对象转换为 JSON

var dataFormItin = $("#formitinerary").serializeArray(); 

结果

itinerary: {
'itinerary[0][date]': undefined,
'itinerary[0][title]': 'Day 1 to Colombo',
'itinerary[0][destinationId]': '5ff3b8d7f0f3bf04b8141362',
'itinerary[0][program]': 'asd',
'itinerary[0][transfer_duration]': '2 hours'
}

我想让它像

itinerary : [
     { date : ..., title :...},
     { date : ..., title :...}
]

1 个答案:

答案 0 :(得分:0)

也许,它会解决你的问题

// 1. Example Data
const serializeArray = [
  { name: "itinerary[0][date]", value: "" },
  { name: "itinerary[0][title]", value: "Day 1 to Colombo" },
  { name: "itinerary[0][destinationId]", value: "5ff3b8d7f0f3bf04b8141362" },
  { name: "itinerary[0][program]", value: "asd" },
  { name: "itinerary[1][date]", value: "" },
  { name: "itinerary[1][title]", value: "Day 1 to Colombo" },
  { name: "itinerary[1][destinationId]", value: "5ff3b8d7f0f3bf04b8141362" },
  { name: "itinerary[1][program]", value: "asd" },
]

// 2. Define object key here
const arrayOfKey = ['date', 'title', 'destinationId', 'program']

// 3. Create empty array object
const arrayObject = []

// 4. Transform Serialize Array into Array Object
for(i = 0; i < serializeArray.length / arrayOfKey.length; i++ ){
  const newObject = {}
  for(const key of arrayOfKey){
    newObject[key] = (serializeArray.find(data => data.name == `itinerary[${i}][${key}]`)).value
  }
  arrayObject.push(newObject)
}

// 5. Show the result
console.log(arrayObject)

/**
 * [
  {
    date: '',
    title: 'Day 1 to Colombo',
    destinationId: '5ff3b8d7f0f3bf04b8141362',
    program: 'asd'
  },
  {
    date: '',
    title: 'Day 1 to Colombo',
    destinationId: '5ff3b8d7f0f3bf04b8141362',
    program: 'asd'
  }
]
 */
相关问题