Home >Web Front-end >JS Tutorial >Introduction to deep cloning of JavaScript objects_javascript skills

Introduction to deep cloning of JavaScript objects_javascript skills

WBOY
WBOYOriginal
2016-05-16 16:28:171464browse

I don’t know when a new word started popping up in the front-end circle: object deep cloning. It may seem very lofty, but in fact it is not new. In our actual project development, you may have already used it. However, due to the broad and profound Chinese characters, some originally simple things are slightly obscured by some seemingly professional vocabulary. Add embellishments and it becomes mysterious.

Why deep clone an object in the first place? Please allow me to make a guess: You must sometimes think that the built-in object document of js is too long, then you may do this:

Copy code The code is as follows:

var d = document;
d.by = function(id){
Return d.getElementById(id);
};
d.by('id').innerHTML = 'hello sentsin';

The above code simplifies document.getElementById, and also adds a by member method to the original document object. You can verify your judgment through the status value returned by document.hasOwnProperty('by'). Look at the following example.

Copy code The code is as follows:

var person = {name: 'Xianxin', profession: 'Front-end development', place: 'Hangzhou'};
var newPerson = person;
newPerson.age = '24';
console.log(person);
//Result: {name: 'Xianxin', profession: 'Front-end development', place: 'Hangzhou', age: 24}

It can be seen that when an object is simply passed to a new variable, it only adds an alias to the object. This means that by operating on the alias, the original object key value will change. But the problem is that sometimes we want newPerson to be completely independent of person and there is no synchronization relationship between them, so we need to generate a copy, please see the example:

Copy code The code is as follows:

var cloneObj = function(obj){
var str, newobj = obj.constructor === Array ? [] : {};
If(typeof obj !== 'object'){
         return;
} else if(window.JSON){
         str = JSON.stringify(obj), //Serialized object
​​​​ newobj = JSON.parse(str); //Restore
} else {
for(var i in obj){
newobj[i] = typeof obj[i] === 'object' ?
cloneObj(obj[i]) : obj[i];
}
}
Return newobj;
};


//Test
var obj = {a: 0, b: 1, c: 2};
var arr = [0, 1, 2];
//Perform deep cloning
var newobj = cloneObj(obj);
var newarr = cloneObj(arr);
//Delete members of the new object after cloning
delete newobj.a;
newarr.splice(0,1);
console.log(obj, arr, newobj, newarr);
//Result: {a: 0, b: 1, c: 2}, [0, 1, 2], {b: 1, c: 2}, [1, 2];

This is called object cloning. However, there are a few things that need explanation. The JSON object in the code and its member methods stringify and parse belong to the ECMAScript5 specification. They are respectively responsible for converting an object (including array objects) into a string and restoring it, thereby realizing a deep copy of the object. So for low-level browsers (such as IE), if you copy an array, you can use newobj.concat(obj), and for ordinary objects, you can simply enumerate and assign values.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn