JS 手写 new 函数

工作中我们经常会用到 new 关键字,new 一个构造函数生成一个实例对象,那么new的过程中发生了什么呢,我们今天梳理下

  1. 创建一个对象
  2. 对象原型继承
  3. 绑定函数this
  4. 返回对象

先创建一个构造函数,原型上添加一个方法

javascript 复制代码
let Foo = function (name) {
  this.name = name
}

Foo.prototype.getName = function () {
  return this.name
}

然后,我们实现一个自定义new函数:

javascript 复制代码
function new_(fn, ...args) {
  let obj = {} // 创建一个对象
  obj.__proto__ = fn.prototype // 继承函数的原型
  fn.apply(obj, args) // 绑定this
  return Object.prototype.toString.call(obj) === '[object Object]' ? obj : {} // 返回对象,判断其有效性
}

使用,看下效果

javascript 复制代码
let foo = new_(foo, '张三')

console.log(foo)
console.log(foo.getName())

打印看下,看到完美输出

相关推荐
p***h64339 分钟前
JavaScript在Node.js中的异步编程
开发语言·javascript·node.js
散峰而望42 分钟前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
Porunarufu43 分钟前
Java·关于List
java·开发语言
N***73851 小时前
Vue网络编程详解
前端·javascript·vue.js
子不语1801 小时前
Python——函数
开发语言·python
ndjnddjxn1 小时前
Rust学习
开发语言·学习·rust
月光技术杂谈2 小时前
实战:C驱动框架嵌入Rust模块的互操作机制与完整流程
c语言·开发语言·rust·ffi·跨语言·bindgen·互操作
t198751282 小时前
基于MATLAB的指纹识别系统完整实现
开发语言·matlab
笑非不退2 小时前
C# c++ 实现程序开机自启动
开发语言·c++·c#
专注于大数据技术栈2 小时前
java学习--final
java·开发语言·学习