原型和原型链

    我们知道在JavaScript中什么都是对象,但是对象主要分为两类:普通对象(Object)和函数对象(Function)。

理解了这两种对象也就能更好的理解原型对象和原型链。

function Animal(){}
    Animal.prototype存储的值就是原型对象,该对象可以理解为Animal的一个实例。也就是在函数对象声明的时候创建的,

并且赋值给prototype。

var animal = new Animal();
    animal.prototype的输出值为undefined,因为animal是一个实例对象,prototype属性只存在于函数对象中。

但是animal该实例对象还是有__proto__属性的,该属性指向的是构造函数所在的函数对象的prototype。

    我们在实现继承时,可以将Animal的prototype值设置为父类的实例对象,这样子类就有了父类的所有属性和方法。
因为我们在查找一个属性时,会现在实例对象上去找,如果没有的话就会在prototype去找。所以,prototype上的属性和方法
是所有实例对象所共有的,有一个实例对象修改该了值,其他示例对象也是可以看到的。
    这样,因为实例对象没有prototype属性,所以如果自身实例对象没有属性时,会基于__proto__到prototype上去找。
每个对象都有__proto__属性,该属性的链接就构成了原型链。

    还有,我们知道instanceof和typeof是有区别的,

function Person(){};
function Student(){};
var p =new Person();
Student.prototype=p;//继承原型
var s=new Student();
console.log(s instanceof Student);//true
console.log(s instanceof Person);//true

    instanceof会去检查Student和Person的prototype是否存在于s的原型链上。

    typeof用以获取一个变量或者表达式的类型,typeof一般只能返回如下几个结果:

        number,boolean,string,function(函数),object(NULL,数组,对象),undefined。

    typeof遇到null,数组,对象时都会返回object类型,所以当我们要判断一个对象是否是数组时或者判断某个变量是否是某个对象的实例则要选择使用另一个关键语法instanceof。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值