函数返回数组的Javascript`new`关键字

我正在尝试使用new关键字,但我无法找到此行为的解释.
假设我们有一个函数返回一个整数:

(在萤火虫中)

>>> function x() { return 2; }
>>> x()
2
>>> new x()
x { }

但是如果函数返回一个数组:

>>> function y() { return [2]; }
>>> y()
[2]
>>> new y()
[2]

这是为什么 ?

解决方法

new运算符有一个有趣的行为:它返回运算符创建的对象,除非构造函数返回另一个对象.忽略构造函数的任何非对象返回值,这就是为什么当你返回2时你没有看到这个.

这是当你说新的x()时会发生什么:

>解释器创建一个新的空白对象.
>它将对象的底层原型设置为x.prototype.
>它将x设置为新对象.
>在正常情况下,x不返回任何内容,新表达式的结果是在步骤1中创建的新对象.但是,如果x返回非空对象引用,则该对象引用是新结果表达式而不是步骤1中创建的对象.忽略任何其他类型的返回值(null,原始数字,原始字符串,未定义等);它必须是非null对象引用,才能优先于新创建的对象.

通过new运算符对对象引用进行的这种特殊处理允许您将另一个对象替换为新创建的对象.这在某些有限的情况下可以很方便,但绝大多数情况下,一个设计用于new(称为构造函数)的函数不应该返回任何东西.

对于某些轻读(hah!),这由规范(HTML; PDF)的Section 13.2.2(“[[Construct]]”)涵盖,其由Section 11.2.2(“新运算符”)引用.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)