โคลนแผนที่หรือชุด ES6 แบบตื้น


คำตอบ:


203

ใช้ตัวสร้างเพื่อโคลนแผนที่และชุด:

var clonedMap = new Map(originalMap)

var clonedSet = new Set(originalSet)

3
วิธีการทำโคลนลึก?
บิล

3
ลองดูซอตัวนี้เพื่อดูวิธีการโคลนแผนที่อย่างละเอียด: jsfiddle.net/pahund/5qtt2Len/1
Patrick Hund

5
Mapควรถือว่าเป็นชนิดข้อมูลนามธรรมไม่ใช่วัตถุ Javascript ดังนั้นการโคลนลึกจึงMapไม่สมเหตุสมผล

5
น่าเสียดายที่ตัวสร้างการคัดลอกไม่ทำงานใน IE 11 (สร้างแผนที่ว่าง)
ม.ค. Molnar

4

การสร้าง Set ใหม่ผ่านทาง for loop นั้นเร็วกว่า Set constructor เช่นเดียวกับ Maps แม้ว่าจะน้อยกว่าก็ตาม

const timeInLoop = (desc, loopCount, fn) => {
  const d = `${desc}: ${loopCount.toExponential()}`
  console.time(d)
  for (let i = 0; i < loopCount; i++) {
    fn()
  }
  console.timeEnd(d)
}

const set = new Set([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])

const setFromForLoop = x => {
  const y = new Set()
  for (const item of x) y.add(item)
  return y
}

const map = new Map([['a', 1], ['b', 2], ['c', 3], ['d', 4], ['e', 5]])

const mapFromForLoop = x => {
  const y = new Map()
  for (const entry of x) y.set(...entry)
  return y
}

timeInLoop('new Set(set)', 1e5, () => new Set(set))

timeInLoop('setFromForLoop(set)', 1e5, () => setFromForLoop(set))

timeInLoop('new Map(map)', 1e5, () => new Map(map))

timeInLoop('mapFromForLoop(map)', 1e5, () => mapFromForLoop(map))


พบดี! อาจเป็นการคุ้มค่าที่จะสร้างจุดบกพร่องบนตัวติดตามข้อบกพร่องของ Chromium เพื่อเรียกร้องความสนใจของพวกเขา สิ่งนี้แก้ไขได้แน่นอนในเครื่องยนต์ ในทำนองเดียวกันสำหรับ Firefox ซึ่งแสดงปัญหาเดียวกันสำหรับSet(แม้ว่าจะไม่ใช่สำหรับMap)
Jo Liss
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.