猿问

对象的映射函数(而不是数组)

对象的映射函数(而不是数组)

我有一个对象:

myObject = { 'a': 1, 'b': 2, 'c': 3 }

我正在寻找一个本机方法,类似于Array.prototype.map将使用如下:

newObject = myObject.map(function (value, label) {
    return value * value;});// newObject is now { 'a': 1, 'b': 4, 'c': 9 }

JavaScript是否具有map对象的这种功能?(我想将它用于Node.JS,所以我不关心跨浏览器问题。)


慕姐8265434
浏览 682回答 3
3回答

暮色呼如

没有原生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都会添加一个新的键,其正方形为值。

函数式编程

没有本地方法,但是lodash#mapValues可以很好地完成工作_.mapValues({ 'a': 1, 'b': 2, 'c': 3} , function(num) { return num * 3; });// → { 'a': 3, 'b': 6, 'c': 9 }
随时随地看视频慕课网APP
我要回答