使用json對(duì)象轉(zhuǎn)化為key,value的對(duì)象數(shù)組
json對(duì)象轉(zhuǎn)為key,value對(duì)象數(shù)組
問(wèn)題引出
在某個(gè)從后端獲取的表格數(shù)據(jù)中,有一列是對(duì)象格式,不能用于直接展示。
解決方式
不直接展示此列,在操作列加一個(gè)按鈕,點(diǎn)擊之后彈窗展示那一列的數(shù)據(jù),形式為key和value的兩列表格,key為該對(duì)象的各個(gè)字段名,value為字段值。這就需要將對(duì)象轉(zhuǎn)化為key和value形式的對(duì)象數(shù)組。
代碼
const metaData = {"api-type": "apiparser", "management.port": "8101"}
Object.entries(metaData).map(([key, value]) => ({
key, value
}))
效果

key,value的對(duì)象數(shù)組轉(zhuǎn)化為json對(duì)象
arr.reduce((acc, curr) => {
acc[curr.key] = curr.value
return acc
}, {})函數(shù)式
/**
* 傳入對(duì)象得到 key、value 形式的對(duì)象數(shù)組
* key、value可以自定義
* @param {Object} MAP 要處理的對(duì)象
* @param {String} key 對(duì)象的key
* @param {String} value 對(duì)象的value
* @returns 數(shù)組
*/
export function mapToJson(MAP, key, value) {
return Object.keys(MAP).map(item => ({
[key]: item,
[value]: MAP[item],
}))
}數(shù)組轉(zhuǎn)換成json key-value形式
eg1(數(shù)組中包含的是數(shù)組)
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(數(shù)組中包含的是對(duì)象)
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' }以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
深入了解JavaScript中遞歸的理解與實(shí)現(xiàn)
本文將通過(guò)遞歸的經(jīng)典案例:求斐波那契數(shù)來(lái)講解遞歸,通過(guò)畫遞歸樹的方式來(lái)講解其時(shí)間復(fù)雜度和空間復(fù)雜度以及遞歸的執(zhí)行順序,感興趣的可以了解一下2022-06-06
Three.js+React制作3D夢(mèng)中海島效果
深居內(nèi)陸的人們,大概每個(gè)人都有過(guò)大海之夢(mèng)吧。本文使用React+Three.js技術(shù)棧,實(shí)現(xiàn)3D海洋和島嶼,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-05-05
IE6-IE9不支持table.innerHTML的解決方法分享
讓ie6-ie9支持table.innerHTML,其實(shí)這里只是對(duì)table做了處理,對(duì)其他不支持的元素可以用類似的方案2012-09-09
javaScript實(shí)現(xiàn)一個(gè)隊(duì)列的方法
這篇文章主要介紹了javaScript實(shí)現(xiàn)一個(gè)隊(duì)列的方法,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07
解析瀑布流布局:JS+絕對(duì)定位的實(shí)現(xiàn)
本篇文章是對(duì)瀑布流局部的實(shí)現(xiàn)進(jìn)行了詳細(xì)的分析介紹。需要的朋友參考下2013-05-05
微信網(wǎng)頁(yè)授權(quán)并獲取用戶信息的方法
這篇文章主要介紹了微信網(wǎng)頁(yè)授權(quán)并獲取用戶信息的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-07

