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

搞清楚 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

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

java:使用匿名直接new接口

java中的匿名有一个倍儿神奇的用法,见下面代码示例: 1 package contract; 2 3 public interface ISay { 4 void sayHello();...contract.ISay; 3 public class Program { 4 public static void main(String[] args) { 5 ISay say = new...; 8 } 9 }; 10 } 11 } 初看上去,就好象在“不提供接口实现的情况下,直接new了一个接口实例”,对于C#er来说,有一种尽毁三观的赶脚...还好这只是假象,观察bin目录下的class输出,会发现有一个类似Program$1.class的文件,如果反编译观察一下,发现原来是编译器自动生成一个Program$1: 1 package jimmy...; 12 } 13 } 如果有些场合,只需要临时需要创建一个接口的实现,上面的"技巧"可以用来简化代码.

93490

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.7K30

模拟实现 new 操作符(js)

js 不是基于 class 这种静态模式,而是基于原型对象的模式。 所以,在 js 中,new 操作符,其实可以通俗的理解成一个辅助工具,用来辅助函数构造出一个新对象。...得先明确这点,才能知道,的确是可以模拟 new 操作符的。...套用 MDN 对 new 的说明: new 运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。...没错,从引擎角度来看,的确是这样处理,但这些内部属性我们并没有办法看到的啊,那对于我们这些写 js 的来说,如何判断一个函数是否能够作为构造函数呢?靠经验积累?...还可以接收一个可选的第三个参数: Reflect.construct(target, argumentsList[, newTarget]) target: 被调用的构造函数 argumentsList:参数列表,数组类型数据

3.5K10

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

JS面向对象二:this/原型链/new原理 阮一峰JavaScript教程:面向对象编程 阮一峰JavaScript教程:实例对象与 new 命令 阮一峰JavaScript教程:this 关键字 也可以看看这篇文章周大侠啊...但是由于回调函数的调用者往往不是我们自己,而是回调函数的接收者,即某个库或框架、甚至是JS运行时环境。...写成代码就是: var obj = new Object({ flag: 10 }); 就像前面所说,机器用来制造某一对象。...正因如此,机器可以作为这类对象的标志,即面向对象语言中(class)的概念。所以机器又被称为构造函数。在ES6引入class关键字之前,我们常常把构造函数叫做。...- 方应杭的文章 - 知 周大侠啊 进击的 JavaScript 之 (七) 原型链 周大侠啊 进击的 JavaScript (八) 之 继承 new() 看看这篇文章很清楚: JSnew 到底是干什么的

2K30

第九节 js里的new方法

new 操作符 在有上面的基础概念的介绍之后,在加上new操作符,我们就能完成传统面向对象的class + new的方式创建对象,在JavaScript中,我们将这类方式成为Pseudoclassical...于是我们看到了: 构造子中,我们来设置‘’的成员变量(例如:例子中的id),构造子对象prototype中我们来设置‘’的公共方法。...于是通过函数对象和Javascript特有的proto与prototype成员及new操作符,模拟出实例化的效果。...如果上面有看着云里雾里的同学 总结一句话就是 如果new的不是对象,是构造函数,new + 构造函数生成对象。 如果单就调用方法而言,确实不必用new。...new一般用在“js使用原型和this关键字实现面向对象”的过程中。

1.9K10
领券