JS笔记!Map 与其余数据结构的互相转换

Map 与其余数据结构的互相转换

PS:仅做为一个学习笔记供日后翻阅!es6

(1)Map 转为数组
Map 转为数组最方便的方法,就是使用扩展运算符(...)。json

const myMap = new Map()
  .set(true, 7)
  .set({foo: 3}, ['abc']);
[...myMap]
// [ [ true, 7 ], [ { foo: 3 }, [ 'abc' ] ] ]

(2)数组 转为 Map数组

将数组传入 Map 构造函数,就能够转为 Map。数据结构

new Map([
  [true, 7],
  [{foo: 3}, ['abc']]
])
// Map {
//   true => 7,
//   Object {foo: 3} => ['abc']
// }

(3)Map 转为对象函数

若是全部 Map 的键都是字符串,它能够转为对象。学习

function strMapToObj(strMap) {
  let obj = Object.create(null);
  for (let [k,v] of strMap) {
    obj[k] = v;
  }
  return obj;
}

const myMap = new Map()
  .set('yes', true)
  .set('no', false);
strMapToObj(myMap)
// { yes: true, no: false }

(4)对象转为 Mapcode

function objToStrMap(obj) {
  let strMap = new Map();
  for (let k of Object.keys(obj)) {
    strMap.set(k, obj[k]);
  }
  return strMap;
}

objToStrMap({yes: true, no: false})
// Map {"yes" => true, "no" => false}

(5)Map 转为 JSON对象

Map 转为 JSON 要区分两种状况。一种状况是,Map 的键名都是字符串,这时能够选择转为对象 JSON。字符串

function strMapToJson(strMap) {
  return JSON.stringify(strMapToObj(strMap));
}

let myMap = new Map().set('yes', true).set('no', false);
strMapToJson(myMap)
// '{"yes":true,"no":false}'

另外一种状况是,Map 的键名有非字符串,这时能够选择转为数组 JSON。get

function mapToArrayJson(map) {
  return JSON.stringify([...map]);
}

let myMap = new Map().set(true, 7).set({foo: 3}, ['abc']);
mapToArrayJson(myMap)
// '[[true,7],[{"foo":3},["abc"]]]'

(6)JSON 转为 Map

JSON 转为 Map,正常状况下,全部键名都是字符串。

function jsonToStrMap(jsonStr) {
  return objToStrMap(JSON.parse(jsonStr));
}

jsonToStrMap('{"yes": true, "no": false}')
// Map {'yes' => true, 'no' => false}

可是,有一种特殊状况,整个 JSON 就是一个数组,且每一个数组成员自己,又是一个有两个成员的数组。这时,它能够一一对应地转为 Map。这每每是数组转为 JSON 的逆操做。

function jsonToMap(jsonStr) {
  return new Map(JSON.parse(jsonStr));
}

jsonToMap('[[true,7],[{"foo":3},["abc"]]]')
// Map {true => 7, Object {foo: 3} => ['abc']}

来源于:http://es6.ruanyifeng.com/#do...

相关文章
相关标签/搜索