首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

深入理解New操作符

前言 当我们对函数进行实例化时,需要用new操作符来实现。那么,对于它的底层实现原理你是否清楚呢?本文就跟大家分享下它的原理并用一个函数来模拟实现它,欢迎各位感兴趣的开发者阅读本文。...原理分析 我们通过一个具体的例子来看下一个函数在new之后都能做些什么,如下所示: function Person(name, age) { this.name = name; this.age...Person.prototype.printBodyWeight = function() { console.log(this.name + "体重为: " + this.bodyWeight); }; 接下来,我们用new...关键字将Person函数进行实例化,我们发现实例化后,可以访问到: 函数内部的属性 函数原型上的属性 const person = new Person("神奇的程序员", "22"); console.log...我们发现: 只能访问我们在构造函数中所返回的属性 构造函数中声明的其它属性以及挂载在原型上的属性均无法访问 image-20221005160504245 实现思路 经过前面的分析,我们知道了函数在new

26430

模拟实现 new 操作符(js)

所以,在 js 中,new 操作符,其实可以通俗的理解成一个辅助工具,用来辅助函数构造出一个新对象。所以,我们才能够来模拟实现它,因为它其实通俗理解,就是一个工具函数。...得先明确这点,才能知道,的确是可以模拟 new 操作符的。...new 操作符其实就是做了几件事: 创建一个继承自 A.prototype 的空对象 让空对象作为函数 A 的上下文,并调用 A 返回这个空对象 这是基本的 new 使用的场景,那么我们要来模拟实现的话...并没有 要模拟实现一个完整的 new 操作符,就还得将它的其他使用场景都考虑进去: 当构造函数有返回值时 判断一个函数是否能够作为构造函数使用 先来考虑第一种: function A() { this.a...——(来自于MDN) 其实这句解释就把 new 操作符的所有职责或者说所有使用场景覆盖了: 用户定义的对象类型 ==> 当构造函数有返回值时 具有构造函数的内置对象 ==> 当前函数可用来作为构造函数,

3.5K10

JavaScript 构造函数和 new 操作符

构造器和操作符 "new" 常规的 {...} 语法允许创建一个对象。但是我们经常需要创建许多类似的对象,例如多个用户或菜单项等。 这可以使用构造函数和 "new" 操作符来实现。...它们只能由 "new" 操作符来执行。...alert(user.name); // Jack alert(user.isAdmin); // false 复制代码 当一个函数被使用 new 操作符执行时,它按照以下步骤: 一个新的空对象被创建并分配给...// 带 "new": new User(); // function User { ... } 复制代码 它可以被用在函数内部,来判断该函数是被通过 new 调用的“构造器模式”,还是没被通过 new...new.target) { // 如果你没有通过 new 运行我 return new User(name); // ……我会给你添加 new } this.name = name;

34830

如何自己实现 JavaScript 的 new 操作符

前言 new 大家肯定都不陌生,单身没有对象的时候就 new 一个,很方便。那么它在创建实例的时候,具体做了哪些操作呢?今天我们就来一起分析一下。...构造函数 在介绍 new 之前,必须要知道什么是构造函数。 构造函数和普通函数在写法上没有任何区别,当一个函数通过 new Fun() 调用时,就叫做构造函数,构造函数首字母通常大写。...new 操作符 那么 new 操作符到底做了什么事情呢,可以创建出一个实例? new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。...以上引用自 new 操作符 - MDN 可能第 2、4 步大家看的不是很明白,这里我重新总结一下这 4 个步骤: 创建一个空对象 u = {} 绑定原型,u....知道了 new 操作符的原理,下面我们自己来实现一个 FakeNew 函数。

41430

C# new关键字和对象类型转换(双括号、is操作符、as操作符)

一、new关键字 CLR要求所有的对象都通过new来创建,代码如下: Object obj=new Object(); 以下是new操作符做的事情 1、计算类型及其所有基类型(一直到System.Object...注:没有和new操作符对应的delete操作符,换言之,没有办法显示释放为对象分配的内存.CLR采用了垃圾回收机制,能自动检测到一个对象不在被使用或者访问,并自动释放对象的内存....C#中进行类型转换的另一种方式是使用is操作符,is检查对象是否兼容于指定类型,返回boolean值true或者false,注意:is操作符永远不抛出异常,代码如下: public class...is操作符通常像下面这样使用: if (stu is Person) { Person p = (Person)stu; } 在上述的代码中,CLR实际进行了两次的代码检查,is操作符首先核实stu...为了简化is操作符的做法,同时提供is操作符的性能,C#专门提供了as操作符,as操作符的工作方式与强制类型转换一样,只是它永远不抛出异常,如果对象不能转换,结果就是null.所以正确使用as操作符的做法是检查转型结果是否为

90590

JS 原生方法原理探究(三):如何实现 new 操作符

本文会介绍如何模拟实现 new 操作符。关于 new 的具体用法,MDN 已经描述得很清楚了,这里我们只做简单的介绍,具体的重点在于如何模拟实现。...new 操作符的规范 下面展示的所有规范都是 ES5 版本的,与现在最新的规范有些区别 首先看一下根据规范的描述, new 操作符做了什么事: ?...全是英文,不过没关系,我简单翻译一下: 我在使用 new 操作符的时候,后面跟着的构造函数可能带参数,也可能不带参数,如果不带参数的话,比如说 new Fn(),那么这里这个 Fn 就是一个 NewExpression...这两种情况下使用 new 操作符所进行的操作有点点不同,这里拿带参数的情况说明一下: 首先会对 Fn 这个 MemberExpression 求值,其结果是指向实际函数对象的一个引用,我们把这个引用作为...returnValue : instance } 注意几个要点: 当函数是通过 new 调用的时候,new.target 会指向函数自身,这个“指向”的操作在代码里就是通过 myNew.target =

98020

【Kotlin 协程】Flow 操作符 ② ( 末端操作符 | collect 操作符 | reduce 操作符 | single 操作符 | first 操作符 | toList 操作符 )

文章目录 一、末端操作符 1、collect 操作符 2、reduce 操作符 3、single 操作符 4、first 操作符 5、fold 操作符 6、toList 操作符 7、toSet 操作符...一、末端操作符 ---- 末端操作符 指的是 在 Flow 流最末端 调用 挂起函数 收集元素 的操作符 , 最常见的 末端操作符 就是 collect 操作符 ; 常见的末端操作符 : 收集元素 :...collect 操作符原型 : /** * 终端流操作符,使用提供的[动作]收集给定的流。...single 操作符原型 : /** * 终端操作符,等待一个且仅等待一个值发出。...first 操作符原型 : /** * 终端操作符,返回流发出的第一个元素,然后取消流的收集。

75110
领券