我有這樣array的strings:
[
'Back to Main Window: Retour à la fenêtre principale',
'All Client Groups: Tous les groupes de clients',
'Filter by Client: Filtrer par client'
]
我想將其改造成一個object與key/value像這樣對:
{
'Back to Main Window': 'Retour à la fenêtre principale',
'All Client Groups': 'Tous les groupes de clients',
'Filter by Client': 'Filtrer par client'
}
我必須嘗試使用map()& split(),但我得到了這個輸出:
const results = translations.map(translation => {
const [key, value] = translation.split(':');
return { key: value };
});
// results returns an "array" with the "key" word as key for all values :(
// [ { key: ' Retour à la fenêtre principale' },
// { key: ' Tous les groupes de clients' },
// { key: ' Filtrer par client' } ]
//
uj5u.com熱心網友回復:
map在陣列上并將每個專案拆分為': ',然后使用Object.fromEntries:
const arr = [
'Back to Main Window: Retour à la fenêtre principale',
'All Client Groups: Tous les groupes de clients',
'Filter by Client: Filtrer par client'
]
const res = Object.fromEntries(arr.map(e => e.split(": ")))
console.log(res)
uj5u.com熱心網友回復:
@Spectric 的另一種解決方案是使用reduce, 將陣列轉換為物件。
const arr = [
'Back to Main Window: Retour à la fenêtre principale',
'All Client Groups: Tous les groupes de clients',
'Filter by Client: Filtrer par client'
];
function transform(arr) {
return arr.reduce((obj, line) => {
const [key, value] = line.split(': ');
obj[key] = value;
return obj;
}, {});
}
console.log(transform(arr));
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/345363.html
標籤:javascript 数组 目的 函数式编程
下一篇:C#如何在方法中參考物件
