JS中new的过程发生了什么

一、JS中new的过程发生了什么?

从例子看方法

java 复制代码
function WhatNew(name){
	this.name = name
}
let news = new WhatNew('屈小康')

通过简单的构造模型创建对象。在说这个之前你需要了解,prototype和__proto__.

prototype属性:每一个构造函数(function a())都有一个prototype属性,它指向构造函数的指针(constructor)。

而__proto__这个方法是每个对象都包含的一个方法,它也指向(constructor)

js 复制代码
	WhatNew.prototype === news.__proto__ // true

我们都知道对象的继承是通过原型链的,而原型链就是通过__proto__一层一层网往上找而形成原型链的,找到最后找到null。

我们直接为构造函数添加一个原型方法。

js 复制代码
	WhatNew.prototype.add = function(x,y){
	return x + y 
}
news.add(1,2)

news的查找过程,现在自己的原型上查找,找不到再向他的上一层构造函数的原型上找,如果还是没有找到的话,往Object上找,找不到的话返回null

js 复制代码
news.__proto__.__proto__.proto__ == null

Object所以对象的实例,比如我们用的一些对象的方法,虽然你定义了,但是没有用。那就是因为继承了Object的原因。比如toString的等

js 复制代码
news.toString() // "[Object Object]"

接下来说明new的过程发生了那些事情:

1、new先创建一个新的对象

var news = new Object()

2、 我们将这个空对象的proto成员指向whatnew函数的对象prototype成员对象。

news.proto = whatnew.prototype

3、修改whatnew的this到object上面。

4、通过call(obj) 改变this指向

5、最后吧whatnew 返回给news就可以了

2、自己实现一个new方法
js 复制代码
	function Mynew(fun, ...arg){
		let obj = { //定义一个空对象
		__proto__ : fun.prototype // 该空对象的__proto__指向fun.prototype
		}
		fun.apply(obj,arg) //改变this指向obj
		return obj
	}
	function person (age , name){
	this.age = age
	this.name = name 
	}
	let mynew = Mynew(person,'1','2')

这样就实现了一个new的方法。

相关推荐
测试员周周3 分钟前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
杜子不疼.2 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号33 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia3 小时前
Qt——编辑交互功能的实现
开发语言·qt
石山代码4 小时前
C++ 内存分区 堆区
java·开发语言·c++
无风听海4 小时前
C# 隐式转换深度解析
java·开发语言·c#
放下华子我只抽RuiKe55 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
一只大袋鼠5 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
LuminousCPP5 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
XinZong5 小时前
OpenClaw 实现双重心跳(Heartbeat)+ clawreach虾聊项目实现
javascript