暮色呼如
没有原生map的Object对象,但这个怎么样:var myObject = { 'a': 1, 'b': 2, 'c': 3 };Object.keys(myObject).map(function(key, index) {
myObject[key] *= 2;});console.log(myObject);// => { 'a': 2, 'b': 4, 'c': 6 }但您可以使用for ... in以下方法轻松迭代对象:var myObject = { 'a': 1, 'b': 2, 'c': 3 };for (var key in myObject) {
if (myObject.hasOwnProperty(key)) {
myObject[key] *= 2;
}}console.log(myObject);// { 'a': 2, 'b': 4, 'c': 6 }更新很多人都提到以前的方法不返回新对象,而是操作对象本身。就此而言,我想添加另一个返回新对象的解决方案,并保留原始对象:var myObject = { 'a': 1, 'b': 2, 'c': 3 };// returns a new object with the values at each key mapped using mapFn(value)function objectMap(object, mapFn) {
return Object.keys(object).reduce(function(result, key) {
result[key] = mapFn(object[key])
return result }, {})}var newObject = objectMap(myObject, function(value) {
return value * 2})console.log(newObject);// => { 'a': 1, 'b': 4, 'c': 6 }console.log(myObject);// => { 'a': 1, 'b': 2, 'c': 3 }Array.prototype.reduce通过稍微将先前值与当前值合并,将数组减少为单个值。链由空对象初始化{}。在每次迭代时,myObject都会添加一个新的键,其正方形为值。