实现对象的 Map 函数类似 Array.prototype.map

Posted 茴香

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实现对象的 Map 函数类似 Array.prototype.map相关的知识,希望对你有一定的参考价值。

// 实现一个map函数
const targetData = {
  a:2,
  b:3,
  c:4
}
const objMap = (obj,fn)=>{
  if(typeof fn !=="function"){
    throw new TypeError(`${fn} is not a function !`);
  }
  return JSON.parse(JSON.stringify(obj,fn));
}
const tempArr =  objMap(targetData,(key,value)=>{
  if(value%2===0){
    return value/2
  }
  return value
})
console.log(tempArr)//{a: 1, b: 3, c: 2, d: 5}

JSON.stringify()

JSON.stringify(value,replacer, space), 方法用于将 javascript 值转换为 JSON 字符串。 (以上案例为两个参数)
  • value: 必传,要转换的javascript值,通常为对象或数组
  • replacer: 可选,用于转换结果的函数或数组,如果为函数,则JSON.stringify将调用该函数,并传入每个成员的键和值,使用返回值而不是原来值,如果此函数返回undefined,则拍出成员,根对象的键是一个空字符串:""。 如果replacer是一个数组,则仅转换该数组中具有键值的成员。成员的转换顺序与数组中的顺序一样。
  • space:可选,文本添加缩进、空格和换行符,如果space是一个数字,则返回值文本在每个级别缩进指定数目的空格,如果space大于10,则文本缩进10个空格。

以上是关于实现对象的 Map 函数类似 Array.prototype.map的主要内容,如果未能解决你的问题,请参考以下文章

ES5新增函数之一: Array, JSON, String, Date

C# 中类似Java Map功能的语句是啥

是否有对象的`.map`之类的函数?用相同的键创建一个新对象

类数组转数组Array.prototype.slice.call(arrayLike)

JavaScript -- Map数据结构

ES6知识点-Map和Set