Vous pouvez cloner un tableau avec Array#slice
:
console.log(s); // ["bye"], i.e. incorrect
console.log(s.slice()); // ["hi"], i.e. correct
Une fonction que vous pouvez utiliser à la place de console.log
qui n'a pas ce problème est la suivante:
console.logShallowCopy = function () {
function slicedIfArray(arg) {
return Array.isArray(arg) ? arg.slice() : arg;
}
var argsSnapshot = Array.prototype.map.call(arguments, slicedIfArray);
return console.log.apply(console, argsSnapshot);
};
Pour le cas des objets, malheureusement, la meilleure méthode semble être de déboguer d'abord avec un navigateur non WebKit, ou d'écrire une fonction compliquée à cloner. Si vous travaillez uniquement avec des objets simples, où l'ordre des touches n'a pas d'importance et il n'y a pas de fonctions, vous pouvez toujours faire:
console.logSanitizedCopy = function () {
var args = Array.prototype.slice.call(arguments);
var sanitizedArgs = JSON.parse(JSON.stringify(args));
return console.log.apply(console, sanitizedArgs);
};
Toutes ces méthodes sont évidemment très lentes, donc plus encore qu'avec les console.log
s normales , vous devez les supprimer une fois le débogage terminé.