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

理解jsnew

new 操作符 在有上面的基础概念的介绍之后,在加上new操作符,我们就能完成传统面向对象的class + new的方式创建对象,在Javascript,我们将这类方式成为Pseudoclassical...基于上面的例子,我们执行如下代码 var obj = new Base(); 这样代码的结果是什么,我们在Javascript引擎中看到的对象模型是: ? new操作符具体干了什么呢?...例如代码如下: Base.prototype.toString = function() {     return this.id; } 那么当我们使用new创建一个新对象的时候,根据__proto...于是我们看到了: 构造子,我们来设置‘类’的成员变量(例如:例子的id),构造子对象prototype我们来设置‘类’的公共方法。...于是通过函数对象和Javascript特有的__proto__与prototype成员及new操作符,模拟出类和类实例化的效果。

3.3K40

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

JS面向对象二:this/原型链/new原理 阮一峰JavaScript教程:面向对象编程 阮一峰JavaScript教程:实例对象与 new 命令 阮一峰JavaScript教程:this 关键字 也可以看看这篇文章周大侠啊...但是由于回调函数的调用者往往不是我们自己,而是回调函数的接收者,即某个库或框架、甚至是JS运行时环境。...- 方应杭的文章 - 知 周大侠啊 进击的 JavaScript 之 (七) 原型链 周大侠啊 进击的 JavaScript (八) 之 继承 new() 看看这篇文章很清楚: JSnew 到底是干什么的...- 方应杭的文章 - 知乎 new解决了什么 以共有属性对象为模板new出来的新对象的__proto__指向共有属性对象(我把这个对象叫做模板对象,也叫作原型).这样共有属性在内存只需要存一次!...对于this绑定来说,称为new绑定。 想知道 构造器调用 this 的绑定,就要知道 new 到底做了啥了。 先来个 new 的实现。看不懂不要紧,在后面原型链那篇,还会说的。

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

JS 手写: new

# 介绍 MDN-new 运算符 (opens new window) # Try it new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。...通过 new 来创建对象实例。 创建一个对象类型,需要创建一个指定其名称和属性的函数;对象的属性可以指向其他对象,看下面的例子: 当代码 new Foo(...)...new Foo 等同于 new Foo(),也就是没有指定参数列表,Foo 不带任何参数调用的情况。 由构造函数返回的对象就是 new 表达式的结果。...要将新属性添加到相同类型的所有对象,必须将该属性添加到 Car 对象类型的定义。...obj var ret = constructor_func.apply(obj, Array.prototype.slice.call(arguments, 1)); // 如果构造函数明确指定了返回对象

1.2K10

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

43730

搞清楚 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 调用,此时的函数作为一个构造函数,这将调用函数的另一个内部方法...如果构造函数的原型是对象,则让实例的 __proto__ 等于构造函数的 prototype 如果构造函数的原型不是对象,则让实例的 __proto__ 等于 Object 的 prototype 将实例对象绑定为构造函数

98120

javaScript系列:js获取时间new Date()详细介绍

大家好,又见面了,我是全栈君 var myDate = new Date(); myDate.getYear(); //获取当前年份(2位) myDate.getFullYear(); //获取完整的年份...myDate.toLocaleString( ); //获取日期与时间 ========================================================================== JS...第二种方法: var timestamp =(new Date()).valueOf(); 结果:1280977330748 第三种方法: var timestamp=new Date().getTime...我和同事在用js实现一个显示出分析数据所剩大概时间的过程,时间总是变给0,结果很怪异,最后发现获取时间的时候用的是Date.parse(newDate())获取的时间戳把毫秒改成了000显示,所以时间差计算的不准确...http://hovertree.com/menu/javascript/ js单独调用new Date(),例如document.write(new Date()); 显示的结果是:Mar 31 10

3K20
领券