javascript构造函数深度克隆递归

<script type="text/javascript">
			var obj={
				name:'段丛磊',
				gex:18,
				sss:['李伟',18],
				fun:function(){
					name='李伟'
					gex=18
				}
			}
			var obj1={};
			
			var init=function(right1,left1){
				var left1=left1||{},   //当用户传入的有东西就用用户提供的,没有就自己给一个{}对象
				toStr=Object.prototype.toString,//判断是对象还是数组的call改变this指向
				arrStr='[object Array]';//数组
				for (var opo in right1) {   //遍历
					if (right1.hasOwnProperty(opo))  //不继承系统的值
					{
					if (right1[opo]!=='null' && typeof(right1[opo])=='Object') //判断是不是引用值
						{
						if (toStr.call(right1[opo])==arrStr)  //判断是不是数组
						{
							left1[opo]=[];
						}
						else
						{
							left1[opo]={};
						}
						init(right1[opo],left1[opo])   //递归
					    }
						else{
						left1[opo]=right1[opo];   //出口
					}
					}
				}
					return left1;//当我没有传这个的时候
			}
			init(obj,obj1);
		</script>

猜你喜欢

转载自blog.csdn.net/weixin_41472521/article/details/80621529