Javascript中构造函数要注意的一些坑

前言

最近在家看书:《你不知道的Javascript》,看到构造函数调用时会绑定this,就顺便打开控制台输了一些代码,详细测试了一下。

构造函数简单的讲,即定义出来专供new 式调用函数

如:

rush:js;"> function A(b) { this.b = b || 'bbb'; }

然后你就可以通过new ,来构建一个 A 的实例:

rush:js;"> var a = new A('B')

但是,一个首要的坑是,构造函数一个普通函数并无不同,如果你故意不使用new,或忘记用new,都会得到奇怪的错误

rush:js;"> var aa = A('adadada');

这样调用,并不会显式地报错,但实际上隐患深埋:

  1. aa并不是A的实例,而变成了 undefined
  2. 多了一个名为 b 的全局变量,值是 ‘adadada'

这就是无new 调用构造函数的坑。

下面说其他的:

构造函数自身有返回值

比如:

rush:js;"> function A(b) { this.b = b || 'bbb'; return {b: '0000'}; }

这个时候,无论是否使用new来调用A,得到的结果都会相同,即得到一个普通对象:{b:'0000′}

当然,此时是否带 new 调用,还是有一个不同点的,即:不带new时,依然会莫名声明一个 叫 b 的全局变量

既然,构造函数有显式返回值时,会代替认应该返回的this,成为返回值,那么,是不是所有返回值都能覆盖this呢?

测试显式返回值

众所周知,函数都是有返回值的,只是如果没有 return,则会返回undefined.

那么,我就在构造函数里显式返回一个undefined,会怎么样?

rush:js;"> var a = function (){this.b = 'b'; return undefined}; new a(); // {b:'b'}

显式返回一个 undefined ,并不能阻止构造函数调用认行为。

下图是更多测试:

简单的总结:

显式的返回以下值:undefined,null,boolean,number等基础类型,并不会代替 new 式调用认行为。

但显式返回以下值:{},[],RegExp,Date,Function,均会代替 new 调用认返回值 this.

大家都看到了,后者,全都是 对象,是复杂类型。

随手一记

前面说过,本该进行 new 式调用的构造函数,被当作普通函数调用,那么,如果函数体中,有 this.x = xxx 这样的赋值语句,则会被赋值给全局对象(即 windows),从而变成一个全局变量

原因相信大家都知道,而本书中也专门讲过:函数调用时,认的this就是绑定至全局对象。

而本书还提到:如果函数体是严格模式,则不会绑定 this 至全局对象,如:

rush:js;"> var a = function (){'use strict';this.b = 'b'; return /111/g}; a(); // 直接报错

因为严格模式下,认的 this 指向 undefined

所以说,有两点要提一下:

  1. 严格模式真不错
  2. 如果你想声明一个构造函数,那么严格模式是非常必要的

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...