JSON.parse(JSON.stringify(obj)) we generally use for deep copy, the process is to use JSON.stringify to serialize the js object (JSON string), and then use JSON.parse to de-serialize (restore) the js object; serialization is to store (the object itself stores only an address mapping, if the power is off, the object will no longer exist, so the content of the object needs to be converted. For example, if the requested Content-Type is application/x-www-form-urlencoded, the front-end side needs to use qs.stringify(data) to serialize the parameters and then pass them to the back-end, otherwise the back-end can not accept them; ps: Content-Type is application/json;charset=UTF-8 or multiform/part-data may not be needed; When we use JSON.parse (JSON.stringify (xxxx)), we should pay attention to several points:
1. If there is a time object in obj, the result of JSON.stringify and JSON.parse will be time only in the form of a string. It's not a time object.
var test = { name: 'a', date: [new Date(1536627600000), new Date(1540047600000)], }; let b; b = JSON.parse(JSON.stringify(test))
data:image/s3,"s3://crabby-images/a05ba/a05baaf99298d5f76573083022a454c3c0a8f21b" alt=""
data:image/s3,"s3://crabby-images/98797/987972bd4db07eba2399d0a4b2dd35a6c8ed03cb" alt=""
data:image/s3,"s3://crabby-images/b1402/b1402f823560beb41004d143dbd690d65b305e09" alt=""
2. If there are RegExp and Error objects in obj, the result of serialization will only get empty objects.
const test = { name: 'a', date: new RegExp('\\w+'), }; // debugger const copyed = JSON.parse(JSON.stringify(test)); test.name = 'test' console.error('ddd', test, copyed)
data:image/s3,"s3://crabby-images/50e50/50e50d03034d66f535f02644fdd280c095883bcc" alt=""
3. If there is a function in obj, undefined, the result of serialization will lose the function or undefined.
const test = { name: 'a', date: function hehe() { console.log('fff') }, }; // debugger const copyed = JSON.parse(JSON.stringify(test)); test.name = 'test' console.error('ddd', test, copyed)
data:image/s3,"s3://crabby-images/e4693/e469364d03d218583cebf6a69c2d4ec204517ae0" alt=""
data:image/s3,"s3://crabby-images/88b44/88b44a21608b8cb4aa3d36d26c1da09c67a8abb3" alt=""
4. If there are NaN, Infinity and - Infinity in obj, the serialized result will become null
data:image/s3,"s3://crabby-images/8c453/8c4530c3771569e8e0496c4add59fceacefb606f" alt=""
5. JSON.stringify() can only serialize enumerable attributes of an object. For example, if the object in obj is generated by a constructor, the constructor of the object will be discarded after a deep copy of JSON.parse(JSON.stringify(obj)).
function Person(name) { this.name = name; console.log(name) } const liai = new Person('liai'); const test = { name: 'a', date: liai, }; // debugger const copyed = JSON.parse(JSON.stringify(test)); test.name = 'test' console.error('ddd', test, copyed)
data:image/s3,"s3://crabby-images/5a21b/5a21b75a2eeeaf2c1d5bed5deec9a70aa75d2c51" alt=""
6. If there are circular references in the object, the deep copy can not be realized correctly.
Above, if the object of the copy does not involve the situation mentioned above, we can use JSON.parse(JSON.stringify(obj)) to achieve deep copy, but when it comes to the above situation, we can consider the following methods to achieve deep copy:
function deepClone(data) { const type = this.judgeType(data); let obj; if (type === 'array') { obj = []; } else if (type === 'object') { obj = {}; } else { // No longer has the next level return data; } if (type === 'array') { // eslint-disable-next-line for (let i = 0, len = data.length; i < len; i++) { obj.push(this.deepClone(data[i])); } } else if (type === 'object') { // The method on the prototype is also copied. // eslint-disable-next-line for (const key in data) { obj[key] = this.deepClone(data[key]); } } return obj; }, function judgeType(obj) { // tostring returns constructors corresponding to different tags const toString = Object.prototype.toString; const map = { '[object Boolean]': 'boolean', '[object Number]': 'number', '[object String]': 'string', '[object Function]': 'function', '[object Array]': 'array', '[object Date]': 'date', '[object RegExp]': 'regExp', '[object Undefined]': 'undefined', '[object Null]': 'null', '[object Object]': 'object', }; if (obj instanceof Element) { return 'element'; } return map[toString.call(obj)]; },
Recommended information
1,JavaScript Object Serialization Explanation
2,Implementation of Shallow Copy and Deep Copy in javaScript