如何将JSON对象转换成键值对数组,实现长尾词疑问?

2026-04-02 21:252阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计550个文字,预计阅读时间需要3分钟。

如何将JSON对象转换成键值对数组,实现长尾词疑问?

目录 + JSON对象转换为key, value对象数组 + 问题引出 + 解决方案 + 数组转换为JSON key-value形式 + 示例1(数组中包含的是数组) + 示例2(数组中包含的是对象) + JSON对象转换为key, value对象数组 + 问题引出 + 解决方案 + 在某个从目录开始的路径中 +

目录
  • json对象转为key,value对象数组
    • 问题引出
    • 解决方式
  • 数组转换成json key-value形式
    • eg1(数组中包含的是数组)
    • eg2(数组中包含的是对象)

json对象转为key,value对象数组

问题引出

在某个从后端获取的表格数据中,有一列是对象格式,不能用于直接展示。

解决方式

不直接展示此列,在操作列加一个按钮,点击之后弹窗展示那一列的数据,形式为key和value的两列表格,key为该对象的各个字段名,value为字段值。这就需要将对象转化为key和value形式的对象数组。

代码

const metaData = {"api-type": "apiparser", "management.port": "8101"} Object.entries(metaData).map(([key, value]) => ({ key, value }))

效果

如何将JSON对象转换成键值对数组,实现长尾词疑问?

key,value的对象数组转化为json对象

arr.reduce((acc, curr) => { acc[curr.key] = curr.value return acc }, {})

函数式

/** * 传入对象得到 key、value 形式的对象数组 * key、value可以自定义 * @param {Object} MAP 要处理的对象 * @param {String} key 对象的key * @param {String} value 对象的value * @returns 数组 */ export function mapToJson(MAP, key, value) { return Object.keys(MAP).map(item => ({ [key]: item, [value]: MAP[item], })) }

数组转换成json key-value形式

eg1(数组中包含的是数组)

var jsonData = {}; var arr = [[1, 'boy', 'dabing'], [2, 'girl', 'dabing']]; for (var i = 0; i < arr.length; i++) {     var key = arr[i][1];     var value = arr[i][2];          jsonData[key] = value; } console.log(jsonData['boy'])// 'dabing'

eg2(数组中包含的是对象)

var jsonData = {}; var arr = [ { id: 3, name: 'MAN_MIDDLESCHOOL_STUDENT', value: 'predefine' },              { id: 4, name: 'FEMALE_MIDDLESCHOOL_STUDENT', value: 'predefine' }]; for (var i = 0; i < arr.length; i++) {     var key = arr[i].name;     var value = arr[i].value;     jsonData[key] = value; } console.log(jsonData);//{ MAN_MIDDLESCHOOL_STUDENT: 'predefine', FEMALE_MIDDLESCHOOL_STUDENT: 'predefine' }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持自由互联。

标签:数组

本文共计550个文字,预计阅读时间需要3分钟。

如何将JSON对象转换成键值对数组,实现长尾词疑问?

目录 + JSON对象转换为key, value对象数组 + 问题引出 + 解决方案 + 数组转换为JSON key-value形式 + 示例1(数组中包含的是数组) + 示例2(数组中包含的是对象) + JSON对象转换为key, value对象数组 + 问题引出 + 解决方案 + 在某个从目录开始的路径中 +

目录
  • json对象转为key,value对象数组
    • 问题引出
    • 解决方式
  • 数组转换成json key-value形式
    • eg1(数组中包含的是数组)
    • eg2(数组中包含的是对象)

json对象转为key,value对象数组

问题引出

在某个从后端获取的表格数据中,有一列是对象格式,不能用于直接展示。

解决方式

不直接展示此列,在操作列加一个按钮,点击之后弹窗展示那一列的数据,形式为key和value的两列表格,key为该对象的各个字段名,value为字段值。这就需要将对象转化为key和value形式的对象数组。

代码

const metaData = {"api-type": "apiparser", "management.port": "8101"} Object.entries(metaData).map(([key, value]) => ({ key, value }))

效果

如何将JSON对象转换成键值对数组,实现长尾词疑问?

key,value的对象数组转化为json对象

arr.reduce((acc, curr) => { acc[curr.key] = curr.value return acc }, {})

函数式

/** * 传入对象得到 key、value 形式的对象数组 * key、value可以自定义 * @param {Object} MAP 要处理的对象 * @param {String} key 对象的key * @param {String} value 对象的value * @returns 数组 */ export function mapToJson(MAP, key, value) { return Object.keys(MAP).map(item => ({ [key]: item, [value]: MAP[item], })) }

数组转换成json key-value形式

eg1(数组中包含的是数组)

var jsonData = {}; var arr = [[1, 'boy', 'dabing'], [2, 'girl', 'dabing']]; for (var i = 0; i < arr.length; i++) {     var key = arr[i][1];     var value = arr[i][2];          jsonData[key] = value; } console.log(jsonData['boy'])// 'dabing'

eg2(数组中包含的是对象)

var jsonData = {}; var arr = [ { id: 3, name: 'MAN_MIDDLESCHOOL_STUDENT', value: 'predefine' },              { id: 4, name: 'FEMALE_MIDDLESCHOOL_STUDENT', value: 'predefine' }]; for (var i = 0; i < arr.length; i++) {     var key = arr[i].name;     var value = arr[i].value;     jsonData[key] = value; } console.log(jsonData);//{ MAN_MIDDLESCHOOL_STUDENT: 'predefine', FEMALE_MIDDLESCHOOL_STUDENT: 'predefine' }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持自由互联。

标签:数组