CoffeeScript攻略2.1:克隆物件(深複製)

CoffeeScript Cookbook發表於2011-11-15

問題

你想複製一個物件,包含其所有子物件。

方案

clone = (obj) ->
  if not obj? or typeof obj isnt 'object'
    return obj

  newInstance = new obj.constructor()

  for key of obj
    newInstance[key] = clone obj[key]

  return newInstance

x =
  foo: 'bar'
  bar: 'foo'

y = clone(x)

y.foo = 'test'

console.log x.foo isnt y.foo, x.foo, y.foo
# => true, bar, test

討論

通過賦值來複制物件與通過克隆函式來複制物件的區別在於如何處理引用。賦值只會複製物件的引用,而克隆函式則會建立一個全新的物件,這個新物件會複製原物件的所有屬性,並且對原物件的所有子物件,也會遞迴呼叫克隆函式,複製每個子物件的所有屬性。

下面是一個通過賦值來複制物件的例子:

x =
  foo: 'bar'
  bar: 'foo'

y = x

y.foo = 'test'

console.log x.foo isnt y.foo, x.foo, y.foo
# => false, test, test

顯然,複製之後修改y也就修改了x。


enter image description here

相關文章