js new 与 return
前置:
默认情况下, 函数的返回值是 undefined (即没有定义返回值)。
new 操作符
js 中的 new 操作符,可以是我们像 java 一样,获得一个新的对象,例如:
function Person() {
this.heart = 'red';
}
let per = new Person();
console.log(per.heart); // red
那么,在 new 的时候,内部发生了什么呢?
我们用伪代码模拟一下:
new Person() = {
var obj = {};
obj.__proto__ = Person.prototype;
var result = Person.call(obj);
return typeof result === 'object' ? result : obj;
}
- 创建一个空对象 obj;
- 设置 obj 的原型链:obj -> Person.prototype -> Object.prototype -> null;
- 在 obj 的执行环境中调用(执行) Person 函数;(或者说改变 this 的指向)
- 考察第三步的返回值,无返回值或者返回一个非对象值,则将 obj 返回作为新的对象,否则将返回值作为新的对象返回。
以上就是 new 操作符的运行机制简略版。
与 return 的化学反应
在大致理解了 new 的运行机制之后,答案就呼之欲出了:
如果我们的构造函数 return 的是简单的基本数据类型(undefinded、数字、字符串、布尔),依旧能够正确 new 出想要的对象;
如果构造函数 return 的是对象(包括基本数据类型的包装对象,如:Object('OK') 等),那么我们 new 的时候就得不到想的对象;
下面贴一个实例:
// 示例引自:https://www.jianshu.com/p/ed692646ee7c
function User( name, age){
this.name = name;
this.age = age; // return; // 返回 this
// return null; // 返回 this
// return this; // 返回 this
// return false; // 返回 this
// return 'hello world'; // 返回 this
// return 2; // 返回 this // return []; // 返回 新建的 [], user.name = undefined
// return function(){}; // 返回 新建的 function,抛弃 this, user.name = undefined
// return new Boolean( false); // 返回 新建的 boolean,抛弃 this, user.name = undefined
// return new String( 'hello world'); // 返回 新建的 string,抛弃 this, user.name = undefined
// return new Number( 32); // 返回 新的 number,抛弃 this, user.name = undefined
}
var user = new User("小白",20)
console.log(user);
js new 与 return的更多相关文章
- js arrow function return object
js arrow function return object bug filterData: { type: Object, default: () => {}, required: true ...
- js中的return,return true,return false小结
return 函数执行到这句时会终结,并返回调用函数,而且把表达式的值作为函数的结果返回 return false 可以防止默认的事件行为.例如,默认情况下点击一个<a>元素,页面会跳转 ...
- 在div+css中用到的js代码注意return
今天做了一个项目,美工做好后放在了form中(没有加runat=server),由于用到了服务器控件,所以这里要加,否则报错,关键一段div代码是: <form id="form_re ...
- a链接的onclick与js中的return false
在学习<javascript基础教程>第八版时,有一个小细节开始不是很明白,查了一些资料后,理了一下思路. 例子的html代码: <!DOCTYPE html> <htm ...
- js事件处理程序return false ,preventDefault,returnValue
面试题目中,经常会被问到如何阻止默认行为. 以下是<javascript权威指南>书中的内容,详情可以去看书. 能够取消事件默认操作的方法有三种 1.属性注册的事件处理程序的返回值fals ...
- js中的 return false;
总的来说return false 的作用就是阻止事件的默认行为 1. function check() { if(form.title.value=="") { alert(&qu ...
- JS构造函数中有return
function foo(name) { this.name = name; return name } console.log(new foo('光何')) function bar(name) { ...
- JS 三目运算符和RETURN
以前写的博客,现在搬过来 首先三目运算符和return的正确用法是这样的: (function test(){ var foo = []; return typeof foo === 'object' ...
- js中的return
retrun true: 返回正确的处理结果. return false:分会错误的处理结果,终止处理. return:把控制权返回给页面(如果条件满足,后面的逻辑就不执行了). if(this.in ...
随机推荐
- POJ-1015 Jury Compromise(dp|01背包)
题目: In Frobnia, a far-away country, the verdicts in court trials are determined by a jury consisting ...
- [原]排错实战——解决Tekla通过.tsep安装插件失败的问题
原总结调试排错troubleshootteklaprocess monitorsysinternals 缘起 最近同事使用.tsep安装Tekla插件的时候,Tekla提示该插件已经存在了,需要卸载后 ...
- drf框架知识点总复习
接口 """ 1.什么是接口:url+请求参数+响应数据 | 接口文档 2.接口规范: url:https,api,资源(名词复数), v1,get|post表示操作资源 ...
- python_pycharm控制台输出带颜色
一.书写格式: 设置颜色开始:\033[显示方式;前景色;背景色m] 结束:\033[0m 二.颜色参数: 前景色 背景色 颜色 ----------------------------------- ...
- Python 学习笔记:根据输入年月获取该月的第一天和最后一天
目的: 给定一个时间,比如:2020.02,要求返回所输入月份的第一天及最后一天,比如:('2020.02.01', '2020.02.29') 参考博客:https://blog.csdn.net/ ...
- Python笔记_第三篇_面向对象_9.Python中的"get"和"set"方法(@property和@.setter)
1. 限制访问的问题: 如果学过C# 语言的我们可以知道C# 语言有get和set方法.我们之前想要获取父类中的私有变量,只能通过写一个set和get的函数进行访问或者通过类生成的新关键字来访问私有属 ...
- pip换源源
介绍 """ 1.采用国内源,加速下载模块的速度 2.常用pip源: -- 豆瓣:https://pypi.douban.com/simple -- 阿里:https:/ ...
- html 基础笔记
html 1,一套规则,浏览器认识的规则 2,开发者: 学习Html规则 开发后台程序: -写Html文件(充当模板的作用) -数据库获取数据,然后替换到html文件的指定位置(web框架) 3,本地 ...
- VS2010无法调试页面问题
图片: VS2010报:未能将脚本调试器附加到计算机XXX上的进程iexplore.exe . 已附加了一个调试器”.启动调试失败. 解决:1.以管理员身份打开CMD; 2.运行:regsvr32.e ...
- OfficeidMsoViewer最新版
点击下载 OfficeidMsoViewer最新版