原型和原型链

1、对象的生产方式

  • 基于类的生产对象
  • 基于原型生产对象
    • 构造方法:方法的首字母大写
    • 实例对象:new关键字创建的对象,就是实例对象
    • 函数二义性的由来:函数既可以当作普通函数,又可以当中构造函数

2、原型和原型链

1)构造函数,实例对象,原型对象之间的关系

2)在JS中,只要是由构造函数new出来的对象,都是满足这样的关系,不管是自定义的构造函数还是内置的构造函数

  • JS中的对象大体上分为两大类:普通对象和构造器对象;
  • 无论是普通对象还是构造器对象都有自己的原型对象,通过__proto__隐式属性,可以找到自己的原型对象,若一直网上找会找到null(Object的protoType的__proto__为null);
  • 普通对象和构造器对象的区别在于是否可以实例化;
  • 构造器对象有protoType属性,这个属性指向实例对象的原型对象;
  • 所有构造器对象的原型对象均为Function.protoType;
  • 无论是普通对象还是构造器对象,最终的Constructor指向Function,而Function的Contructor指向自己本身;

3、原型链的实际应用

1)在原型对象上添加属性和方法,虽然允许这样写,但是不推荐;推荐使用创建一个子类继承这个构造函数;

2)实现原型方式继承

4、原型链相关方法

1)Object.getPrototypeOf():查找一个对象的原型对象;

2)instanceOf:判断一个对象是否是一个构造函数的实例;

3)isPrototypeOf():检测一个对象是否是另一个对象的原型对象;

4)hasOwnProperty():判断一个属性是定义在对象本身上面的还是从原型对象上面继承而来的;

相关推荐
山河木马10 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
泯泷11 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
泯泷11 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
朦胧之12 小时前
页面白屏卡住排查方法
前端·javascript
犇驫聊AI13 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript
kyriewen13 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
用户2986985301418 小时前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js
labixiong18 小时前
手写Promise--微任务、静态方法、async/await 全搞懂(三)
前端·javascript
铁皮饭盒20 小时前
3行代码搞定页面截图,Bun.WebView真的简单
javascript
kyriewen1 天前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试