前置:

  默认情况下, 函数的返回值是 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;
}
  1. 创建一个空对象 obj;
  2. 设置 obj 的原型链:obj -> Person.prototype -> Object.prototype -> null;
  3. 在 obj 的执行环境中调用(执行) Person 函数;(或者说改变 this 的指向)
  4. 考察第三步的返回值,无返回值或者返回一个非对象值,则将 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的更多相关文章

  1. js arrow function return object

    js arrow function return object bug filterData: { type: Object, default: () => {}, required: true ...

  2. js中的return,return true,return false小结

    return  函数执行到这句时会终结,并返回调用函数,而且把表达式的值作为函数的结果返回 return false 可以防止默认的事件行为.例如,默认情况下点击一个<a>元素,页面会跳转 ...

  3. 在div+css中用到的js代码注意return

    今天做了一个项目,美工做好后放在了form中(没有加runat=server),由于用到了服务器控件,所以这里要加,否则报错,关键一段div代码是: <form id="form_re ...

  4. a链接的onclick与js中的return false

    在学习<javascript基础教程>第八版时,有一个小细节开始不是很明白,查了一些资料后,理了一下思路. 例子的html代码: <!DOCTYPE html> <htm ...

  5. js事件处理程序return false ,preventDefault,returnValue

    面试题目中,经常会被问到如何阻止默认行为. 以下是<javascript权威指南>书中的内容,详情可以去看书. 能够取消事件默认操作的方法有三种 1.属性注册的事件处理程序的返回值fals ...

  6. js中的 return false;

    总的来说return false 的作用就是阻止事件的默认行为 1. function check() { if(form.title.value=="") { alert(&qu ...

  7. JS构造函数中有return

    function foo(name) { this.name = name; return name } console.log(new foo('光何')) function bar(name) { ...

  8. JS 三目运算符和RETURN

    以前写的博客,现在搬过来 首先三目运算符和return的正确用法是这样的: (function test(){ var foo = []; return typeof foo === 'object' ...

  9. js中的return

    retrun true: 返回正确的处理结果. return false:分会错误的处理结果,终止处理. return:把控制权返回给页面(如果条件满足,后面的逻辑就不执行了). if(this.in ...

随机推荐

  1. 17.3.12--smtplib模块发送邮件__抄送,安装与下载

    1-----在日常编程中,经常会用到处理email,发送,接收,抄送,下载邮件内容等操作,这时候就需要用Python的smtplib模块 smtplib与Email服务器(server)相互通信来传送 ...

  2. UINavigationbar跳转黑色

    bug效果:导航栏过渡出现黑色

  3. day61-mysql-索引原理和慢查询优化

    ProgramData是C盘隐藏的文件夹,mysql的data文件夹在里面,C:\ProgramData\MySQL\MySQL Server 8.0\Data 一.存储引擎 重点[面试题]: inn ...

  4. ZJNU 1528 - War--高级

    类似于1213取水 可以把空投当作第0个城市 最后将0~n的所有城市跑最小生成树 /* Written By StelaYuri */ #include<iostream> #includ ...

  5. 国产手机早就异军突起,为何还是有很多人“迷恋”iPhone?

    近几年,国产手机不论是从外观上还是设计上,以及销量上都比前有了长足的进步,手机的品质和售后也在不断提升.这也让中国手机厂商不断的推出了拥有自己品牌特色的产品.特别是2018年不少国产手机品牌的旗舰级产 ...

  6. CodeForces 990B Micro-World(思维、STL)

    http://codeforces.com/problemset/problem/990/B 题意: 有n个细菌,每个细菌的尺寸为ai,现在有以常数k,如果细菌i的尺寸ai大于细菌j的尺寸aj,并且a ...

  7. Opencv笔记(十六)——认识轮廓

    什么是轮廓? 轮廓可以简单认为成连续的点(连着边界)连在一起的曲线,具有相同的颜色或者灰度.轮廓在形状分析和物体的检测和识别中很有用.谈起轮廓不免想到边缘,它们确实很像.简单的说,轮廓是连续的,边缘并 ...

  8. 900B. Position in Fraction#分数位置(模拟)

    题目出处:http://codeforces.com/problemset/problem/900/B 题目大意:找到一个数字在小数部分中第一次出现的位置 #include<iostream&g ...

  9. nginx限制IP访问网站

    需求:网站只允许指定IP访问,其他访问一律拒绝server { listen 80; server_name a.com; index index.html index.htm index.php; ...

  10. CodeForces 91B Queue (线段树,区间最值)

    http://codeforces.com/problemset/problem/91/B B. Queue time limit per test: 2 seconds memory limit p ...