第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

對象的映射函數(shù)(而不是數(shù)組)

對象的映射函數(shù)(而不是數(shù)組)

慕姐8265434 2019-07-23 15:33:56
對象的映射函數(shù)(而不是數(shù)組)我有一個對象: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,所以我不關心跨瀏覽器問題。)
查看完整描述

3 回答

?
暮色呼如

TA貢獻1853條經驗 獲得超9個贊

沒有原生mapObject對象,但這個怎么樣:

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通過稍微將先前值與當前值合并,將數(shù)組減少為單個值。鏈由空對象初始化{}。在每次迭代時,myObject都會添加一個新的鍵,其正方形為值。


查看完整回答
反對 回復 2019-07-23
?
函數(shù)式編程

TA貢獻1807條經驗 獲得超9個贊

沒有本地方法,但是lodash#mapValues可以很好地完成工作

_.mapValues({ 'a': 1, 'b': 2, 'c': 3} , function(num) { return num * 3; });// → { 'a': 3, 'b': 6, 'c': 9 }


查看完整回答
反對 回復 2019-07-23
  • 3 回答
  • 0 關注
  • 710 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號