原型和原型链

JavaScript中的每个函数都有一个prototype属性,用于解决构造函数中方法内存浪费的问题。通过将实例对象的通用方法放入原型,可以实现方法的共享,如Vue框架中的$router和$store。原型链是对象属性查找机制,从自身到原型逐级查找,实现继承。一切对象都继承自Object,函数对象继承自Function,Function的__proto__最终指向Object。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

js原型也叫做js原型对象是一种对象属性,在Javascript中,每一个函数在创建的时候,系统都会给自动生成一个对象,这个的对象有一个属性,这个属性就是prototype。 主要作用是解决构造函数内部方法内存资源浪费问题。在开发中我们一般把实例对象一些通用的方法放入原型中,在 vue 里面有时候也会给 vue 的原型添加一些公共类方法来实现所有的组件中可以共享成员。像一些常见的$router和$store 都是挂载到 vue 的原型上的。

举个例子:

函数可以有属性。 每个函数都有一个特殊的属性叫作原型prototype

function doSomething() {}
console.log(doSomething.prototype)

控制台输出 

{
    constructor: ƒ doSomething(),
    __proto__: {
        constructor: ƒ Object(),
        hasOwnProperty: ƒ hasOwnProperty(),
        isPrototypeOf: ƒ isPrototypeOf(),
        propertyIsEnumerable: ƒ propertyIsEnumerable(),
        toLocaleString: ƒ toLocaleString(),
        toString: ƒ toString(),
        valueOf: ƒ valueOf()
    }
}

prototype的作用

prototype对象属性多用于构造函数中,因为在构造函数中构造函数的每个方法都是需要在实际运用的对象中重新创建一遍,不能重复使用的。这样会对代码的编写会非常的麻烦和对内存资源造成浪费。
然而,使用prototype原型对象给构造函数添加方法就可以解决这个问题,添加到prototype原型上的方法会被该构造函数,所构造出来的所有对象共享。

原型链是 js 对象一种查找机制,遵循就近原则。当我们访问一个对象中的成员的时候,会优先访问自己的,如果自己没有就访问原型的,如果原型也没有就会访问原型的原型,直到原型链的终点 null. 如果还没有,此时属性就会获取 undefined,方法就会报错 xxx is not a function。一般原型链主要是用来实现面向对象继承的。

下面作出总结:

  • 一切对象都是继承自Object对象,Object 对象直接继承根源对象null

  • 一切的函数对象(包括 Object 对象),都是继承自 Function 对象

  • Object 对象直接继承自 Function 对象

  • Function对象的__proto__会指向自己的原型对象,最终还是继承自Object对象

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值