Maneira mais elegante de clonar um objeto JavaScript

Descobri a melhor maneira de clonar qualquer objeto JavaScript nesta resposta stackoverflow . Esta função é muito útil quando você insere nós no DOM ou os remove dinamicamente:

function clone(obj) {
// Handle the 3 simple types, and null or undefined
if (null == obj || "object" != typeof obj) return obj;

// Handle Date
if (obj instanceof Date) {
var copy = new Date();
copy
.setTime(obj.getTime());
return copy;
}

// Handle Array
if (obj instanceof Array) {
var copy = [];
for (var i = 0, len = obj.length; i < len; i++) {
copy
[i] = clone(obj[i]);
}
return copy;
}

// Handle Object
if (obj instanceof Object) {
var copy = {};
for (var attr in obj) {
if (obj.hasOwnProperty(attr)) copy[attr] = clone(obj[attr]);
}
return copy;
}

throw new Error("Unable to copy obj! Its type isn't supported.");
}

O autor explica que, quando teve que implementar a cópia profunda geral, ele acabou cedendo ao assumir que só precisaria copiar um objeto simples , matriz , data , sequência , número ou booleano . Os últimos 3 tipos são imutáveis, então ele poderia executar uma cópia superficial e não se preocupar com a mudança. Ele também assumiu que quaisquer elementos contidos em Object ou Array também seriam um dos 6 tipos simples nessa lista.