深拷贝浅拷贝/原型/类型校验/递归深拷贝

浅拷贝:

浅拷贝是只拷贝一层,深拷贝是蹭蹭拷贝 将对象的每个属性进行依次复制,当对象的属性是引用类型时实质复制是
其引用,当引用指向的值改变也会发生改变

深拷贝:

复制变量值,对于非基本变量,则递归基本变量后在复制,深拷贝后的对象与原来对象完全隔离不互相影响对一个对象
进行修改不会影响另一个对象

**浅拷贝:**
let a=[0,1,2,3,4],
    b=a;
console.log(a===b);
a[0]=1;
console.log(a,b);
**递归深拷贝**:
function deepClone(obj){
    let objClone = Array.isArray(obj)?[]:{};
    if(obj && typeof obj==="object"){
        for(key in obj){
            if(obj.hasOwnProperty(key)){
                //判断ojb子元素是否为对象,如果是,递归复制
                if(obj[key]&&typeof obj[key] ==="object"){
                    objClone[key] = deepClone(obj[key]);
                }else{
                    //如果不是,简单复制
                    objClone[key] = obj[key];
                }
            }
        }
    }
    return objClone;
}    
let a=[1,2,3,4],
    b=deepClone(a);
a[0]=2;
console.log(a,b);

原型

在这里插入图片描述

原型: 每个函数都有一个prototype显示原型 每个实例都有一个proto隐式原型 实例中的隐式原型指向构造中的显示原型

原型链: 获取对象属性时,如果对象本身没有这个属性那么会去他的原型_proto_上去找,如果找不到就会去原型的原型找,一
直到最顶层 object.prototype为止

类型校验

方法: typeof、instanceof、constructor、Object.prototype.toString.call()、jquery.type()

console.log(typeof 20, //"number"
typeof 'abc', //"string"
typeof [1,2,3], //"object"
);

instanceof

console.log(
    null instanceof Object, //false
    [1,2,3] instanceof Array, //true
    {a:1,b:2,c:3} instanceof Object, //true
)

constructor

console.log(new Number(123).constructor)

Object.prototype.toString.call()


toString.call(123); //"[object Number]"

toString.call('abcdef'); //"[object String]"

toString.call([1, 2, 3, 4]); //"[object Array]"

jquery.type()


jQuery.type() === "undefined"

jQuery.type( null ) === "null"

jQuery.type( true ) === "boolean"

jQuery.type( function(){} ) === "function"

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力奔波的程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值