原型和原型链

所有对象都有一个属性 proto 指向一个对象,也就是原型

每个对象的原型都可以通过 constructor 找到构造函数,构造函数也可以通过 prototype 找到原型

所有函数都可以通过 proto 找到 Function 对象

所有对象都可以通过 proto 找到 Object 对象

引用类型的四个规则

1.引用类型,都具有对象特性,即可以自由扩展属性
2.引用类型,都有一个隐式原型__proto__属性,属性值是一个普通对象
3.引用类型,隐式原型 proto 的属性值指向它的构造函数的显式原型 prototype 属性值。
4.4、当你试图得到一个对象的某个属性时,如果这个对象本身没有这个属性,那么它会去它的隐式原型 proto(也就是它的构造函数的显式原型 prototype)中寻找。

引用类型:Object、Array、Function、Date、RegExp。这里我姑且称 proto 为隐式原型,没有官方中文叫法,大家都瞎叫居多。

什么是原型

1.所有引用类型都有一个__proto__(隐式原型属性),属性值是一个普通的对象

2.所有函数都有一个prototype(原型)属性,属性值是一个普通的对象

3.所有引用类型的__proto__属性值指向它构造函数的显式原型prototype属性值

在js中,每当定义一个函数数据类型(普通函数、类)时,都会天生自带一个prototype属性,这个属性指向函数的原型对象

什么是原型链

当访问一个对象的某个属性时,会先在这个对象本身属性上查找,如果没有找到,则会去它的__proto__隐式原型上查找,即它的构造函数的prototype,如果还没有找到就会再次在构造函数的prototype(是一个对象)__proto__中查找,这样一层一层的向上查找就会形成一个链式结构,我们称为原型链。

1.一直往上层查找,直到到null还没有找到,则返回undefined

2.object.prototype.proto === null

3.所有从原型或更高级原型中的得到和执行的方法,其中的this在执行时,指向当前这个触发事件执行的对象

感觉用代码更容易理解

function Person(name) {
            this.name = name
        }
       // Person.prototype = {}  //默认是一个对象,里面可以有数据
        Person.prototype = {
            age: 18
        }
        console.log(Person.prototype)
        var person1 = new Person('yan')

        console.log(person1.__proto__ == Person.prototype)
        console.log( Person.prototype.__proto__ == Object.prototype)
console.log(person1.__proto__ == Person.prototype)  //true
console.log(Person.prototype.__proto__ == Object.prototype)  //true
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值