2017-04-24 50 views
1

爲什麼'values'數組不包含'results'中每個項目的'Title'?未按預期向陣列添加javascript映射函數

以下代碼輸出:1, 2, 3, 3, 3, 3而不是所需的:1, 2, 3, 1, 2, 3

var results = [ 
 
    {Title: '1'}, 
 
    {Title: '2'}, 
 
    {Title: '3'}, 
 
]; 
 
var fields = { 
 
    Title: { Name:"Title", Required:true}, 
 
    Description: { Name:"Description", Required:false} 
 
}; 
 
var values = []; 
 
results.map(function(result, i){ 
 
    values[i] = fields; 
 
    Object.keys(result).map(function(key, index) { 
 
     values[i][key].Value = result[key]; 
 
    }); 
 
    console.log(values[i].Title.Value); 
 
}); 
 
values.map(function(value){console.log(value.Title.Value)});

+7

如果你不使用它的結果,爲什麼地圖? –

+2

我認爲你在這裏混合* map *和* forEach * ... – Robert

+0

因爲你有一個對象的引用,而不是它的副本。 – epascarello

回答

0

地圖功能不會改變你與它的工作電流陣列返回一個新的改變了其數據,並要啓動值,你要推一個空數組新的價值。

0

var results = [ 
 
    {Title: '1'}, 
 
    {Title: '2'}, 
 
    {Title: '3'}, 
 
]; 
 
var fields = { 
 
    Title: { Name:"Title", Required:true}, 
 
    Description: { Name:"Description", Required:false} 
 
}; 
 
var values = []; 
 
values = results.map(function(result, i){ 
 
    values[i] = fields; 
 
    Object.keys(result).map(function(key, index) { 
 
     values[i][key].Value = result[key]; 
 
    }); 
 
    console.log(values[i].Title.Value); 
 
    });

的地圖()方法創建要求每個數組元素的函數的結果的新的數組。

map()方法按順序爲數組中的每個元素調用一次提供的函數。

注意:map()不會爲沒有值的數組元素執行函數。

注意:map()不會更改原始數組。

0

爲了簡單起見,您應該堅持使用reduce函數來減少和映射字段。

var rawData = [ 
 
    { Title: '1' }, 
 
    { Title: '2' }, 
 
    { Title: '3' }, 
 
] 
 
var fieldInfo = { 
 
    Title  : { Name:"Title",  Required: true }, 
 
    Description : { Name:"Description", Required: false } 
 
} 
 
var result = transformData(rawData, fieldInfo) 
 

 
console.log(JSON.stringify(result, null, 2)) 
 

 
result.forEach(item => console.log('Value: ', item.Title.Value)) 
 

 
function transformData(data, fields) { 
 
    return data.map((record, i) => { 
 
    return Object.keys(fields).reduce((result, key, index) => { 
 
     result[key] = { Value : record[key] || null }; 
 
     // -- Begin field cloning. 
 
     Object.keys(fields[key]).forEach(prop => result[key][prop] = fields[key][prop]); 
 
     // -- End field cloning. 
 
     return result 
 
    }, {}) 
 
    }) 
 
}
.as-console-wrapper { top: 0; max-height: 100% !important; }

+0

謝謝,但爲什麼我不能將'result [key] = {Value:record [key]}'改成'result [key] = fields [key]; result [key] .Value = record [key];' ? – user247298

+0

@ user247298我添加了對克隆字段數據的支持。如果您多次使用該對象,則永遠不想設置對象的引用。只需循環想要複製的對象並克隆其屬性即可。 –

+0

謝謝@ mr-polywirl。如果我想在每個結果返回的對象中包含沒有值的字段,那麼該怎麼辦?描述?我實際上喜歡將Value屬性設置爲「」,而不是在這些字段中未定義。 – user247298