首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS面向对象二:this原型链new原理

JS面向对象二:this/原型链/new原理 阮一峰JavaScript教程:面向对象编程 阮一峰JavaScript教程:实例对象与 new 命令 阮一峰JavaScript教程:this 关键字 也可以看看这篇文章周大侠啊...但是由于回调函数的调用者往往不是我们自己,而是回调函数的接收者,即某个库或框架、甚至是JS运行时环境。...文中: **No. 1:Object.prototype No. 2:Function.prototype** 还有这几篇文章也不错: 「每日一题」什么是 JS 原型链?...- 方应杭的文章 - 知 周大侠啊 进击的 JavaScript 之 (七) 原型链 周大侠啊 进击的 JavaScript (八) 之 继承 new() 看看这篇文章很清楚: JSnew 到底是干什么的...这种方法省内存且好用. new()就是刚刚的所有过程 ? 灰色的代码就是new()做的封装,不需要你做的事情 共有属性被new()统一叫做prototype ? new其实就是语法糖!

2K30
您找到你想要的搜索结果了吗?
是的
没有找到

new原理

new的作用 字面意思是用来调用构造函数(class),产出一个新对象。 就比如你买了个榨汁机(构造函数),然后按启动榨汁按钮(使用new),可以榨出一杯饮料或豆浆。...new的过程 1、(使用Object.create)创建一个新对象,并把它的原型,指向被new的构造函数的原型 2、(使用es6的apply方法)改变构造函数this指向并传参,把它的this指向给新对象...3、返回新对象 new和字面量创建对象的区别 字面量不会调用构造函数,节约性能。...new需要调用构造函数,和一些其他方法,性能消耗更高 手写一个new方法 1function _new(fn, ...arg) { 2 const obj = Object.create(fn.prototype...11 this.sayName = function () { 12 console.log(this.name); 13 }; 14} 15const xiaoMei = _new

44530

搞清楚 js new

new 构造函数里的this以及返回值 /** * new 构造函数里面的this * 默认函数里面的this,谁调用就指向谁, * 但是new 构造函数,这个构造函数里面的this指向是new...,则返回值为new 构造函数出来的实例 * 2,如果返回的是一个非基本数据类型的对象(object),则返回值为指定的对象 * 如果new 构造函数里面没有返回值,默认返回undefined,则返回值还是...('test2') console.log(test2); //{age: 18} 没有new得到的是什么 /** * 首先我们看没有new的时候,得到的是什么 * 根据控制台打印,可知没有new...new得到的是什么--------'); var dog = { name: 'husky' } console.log(dog); new做了什么 /** * new做了什么?...(Cat, 'tom1') console.log(cat1); 简化版实现new /** * new做了什么?

2.4K20

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

这是JS 原生方法原理探究系列的第三篇文章。本文会介绍如何模拟实现 new 操作符。关于 new 的具体用法,MDN 已经描述得很清楚了,这里我们只做简单的介绍,具体的重点在于如何模拟实现。...new 操作符的规范 下面展示的所有规范都是 ES5 版本的,与现在最新的规范有些区别 首先看一下根据规范的描述, new 操作符做了什么事: ?...全是英文,不过没关系,我简单翻译一下: 我在使用 new 操作符的时候,后面跟着的构造函数可能带参数,也可能不带参数,如果不带参数的话,比如说 new Fn(),那么这里这个 Fn 就是一个 NewExpression...[[Constructor]] 的规范 在 JS 中,函数有两种调用方式,一种是正常调用,这将调用函数的内部方法 [[Call]],还有一种是通过 new 调用,此时的函数作为一个构造函数,这将调用函数的另一个内部方法...returnValue : instance } 注意几个要点: 当函数是通过 new 调用的时候,new.target 会指向函数自身,这个“指向”的操作在代码里就是通过 myNew.target =

1K20

js new Date() 默认是8点

然后我通过new Date()传入日期字符串创建了一个对象,并与当前时间做时间戳比较,结果12点刚过,就出问题了。...举个栗子 // 假设当前时间是2019年12月22日0点20分 new Date('2019-12-22').getTime() < new Date().getTime() // 上面的结果是什么?...当时临时解决问题后的字符串大概长这样: new Date('2019/12/22 00:00:00').getTime() < new Date().getTime() 临时解决问题。...那么为什么js会对不同分割的时间字符串进行不同处理呢?貌似是因为-分隔且具有前导0的日期字符串,会被解析成ISO格式的字符串,以GMT时区为基准,不过我也没看懂。...@param dateStr * 时间字符串 */ function getDate(dateStr){ /* 若日期是使用-分割的,全部转换成/ 因为只有日期时,js

8.8K30

模拟实现 new 操作符(js)

js 不是基于 class 这种静态类模式,而是基于原型对象的模式。 所以,在 js 中,new 操作符,其实可以通俗的理解成一个辅助工具,用来辅助函数构造出一个新对象。...得先明确这点,才能知道,的确是可以模拟 new 操作符的。...套用 MDN 对 new 的说明: new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。...没错,从引擎角度来看,的确是这样处理,但这些内部属性我们并没有办法看到的啊,那对于我们这些写 js 的来说,如何判断一个函数是否能够作为构造函数呢?靠经验积累?...emmm,你说的很有道理,是可以这样没错,但这样,不就学不到 new 的职责原理了吗,不就回答不了面试官的提问了吗?

3.5K10

new出对象“原理的深层解密

.✨ 前言 讲解C++中有关new的知识,与malloc进行对比,以及深入探索new的实现原理....ptr1; 1.2 new创建数组 new + 对象的类型 + [个数] + (初始化的值) new + 对象的类型 + [个数] + {num1,num2,…} 需要注意的是,连续的多个空间须使用...(2)new是C++中的运算符。new可以直接在创建对象时进行初始化,并返回一个指向已经构造的对象的指针。new操作符会执行类型检查,确保分配的内存与对象类型匹配。...三、new和delete的深层解密 3.1 解密实现原理 学到这里,我们知道new会代用构造函数,还会抛出异常,那它究竟是怎么实现的呢?...;对应的汇编指令: 会发现,new操作符果然是调用operator new +构造函数.

16430
领券