<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>ES6</title>
</head>
<body>
<!-- function -->
<script>
function deepClone(origin,hasMap=new WeakMap()){
if(origin==undefined&&typeof origin!=="object"){
return origin;
}
if(origin instanceof Date){
return new Date(origin)
}
if(origin instanceof RegExp){
return new RegExp(origin)
}
const hashKey=hasMap.get(origin)
// const target = new origin.constructor();
if(hashKey){
return hashKey
}
hasMap.set(origin,target)
for(let k in origin){
if(origin.hasOwnProperty(k)){
target[k]=deepClone(origin[k],hasMap)
}
}
return target
}
</script>
</body>
</html>
前端学习案例-Es6深拷贝,weakMap解决拷贝死循环问题
原创
©著作权归作者所有:来自51CTO博客作者前端导师歌谣的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
ES6深拷贝与浅拷贝
ES6深拷贝与浅拷贝
ES6 深拷贝 浅拷 -
前端学习案例2-es6的拷贝
前端
学习 es6 前端