Js中的普通函数与构造函数比较

更新日期: 2019-07-21阅读: 2.3k标签: 函数

正文

想必学过javascript函数的同学想必能细心的发现,同样是函数,为什么有个函数要加上new关键字呢,加上他们的意义又是什么,作用于什么场景,下面我们就来给大家详细介绍一下。


问题

  • 什么是构造函数?
  • 构造函数的优点与缺点?
  • 构造函数与普通函数区别是什么?
  • 用new关键字的时候到底做了什么?
  • 构造函数有返回值怎么办?
  • 构造函数能当普通函数调用吗?

什么是构造函数

语法:let person = new Person('lucas','22');

person(实例变量) = 实例函数/方法

无论是构造函数还是非构造函数,两者并没有实质性的区别;构造函数可以作为普通函数使用,普通函数也可以作为构造函数来用;首字母大小写仅仅是为了在开发中能易于区分他们。
无论什么函数:

  • 只要通过 new 操作符来调用,那就是作为构造函数使用,此时this指向new出的实例
  • 如果不通过 new 操作符来调用,那就是作为普通函数使用;此时,在非严格模式下this都指向window

从原型链角度看,它们还是没啥区别

/*普通函数*/
console.log(foo.__proto__ === Function.prototype); //true  
/*构造函数*/
console.log(Foo.__proto__ === Function.prototype); //true

构造函数的优点与缺点

优点就是能够通过instanceof识别对象,缺点是每次实例化一个对象,都会把属性和方法复制一遍

在js中,引用类型比较的是地址, 函数是一种引用类型,而是存在两个不同的内存地址,因为每个对象的属性是不一样的,这个没有什么问题,但是方法执行的都是一样的代码,所以没有必要复制,存在多份,浪费内存.这就是缺点。

怎么解决构造函数的方法复制多次的问题?

function CreateObj(uName) {
   this.userName = uName;
   this.showUserName = showUserName;
}
function showUserName (){ return this.userName; } var obj1 = new CreateObj('ghostwu'); var obj2 = new CreateObj('卫庄'); console.log( obj1.showUserName === obj2.showUserName ); //true

把对象的方法指向同一个全局函数showUserName, 虽然解决了多次复制问题,但是全局函数非常容易被覆盖,也就是大家经常说的污染全局变量.


那么有哪些比较好的解决方案?

通过原型(prototype)对象,把方法写在构造函数的原型对象上

function CreateObj(uName) {
    this.userName = uName;
}
CreateObj.prototype.showUserName = function(){
   return this.userName;
}
var obj1 = new CreateObj('ghostwu');
var obj2 = new CreateObj('卫庄');
console.log( obj1.showUserName === obj2.showUserName ); //true

构造函数与普通函数区别

这是一个简单的普通函数

function fn(){
alert("hello sheila");
}
fn();//alert:hello sheila


普通函数与构造函数相比有四个明显特点:

1.不需要用new关键字调用

person()  //函数调用


2.可以用return语句返回值

function fn(a,b){
   return a+b;
}
alert(fn(2,3));//alert:5


3.函数内部不建议使用this关键字

我们说不建议使用,当然硬要用是可以的,只是要注意这时候发生了什么。如果在普通函数内部使用this关键字定义变量或函数,因为这时候this指向的是window全局对象,这样无意间就会为window添加了一些全局变量或函数。

var name='Dan';  
function greeting(){
   this.name="lucas";
   alert("hello "+this.name);
}
greeting();//alert:hello lucas
alert(window.name);//alert:lucas
alert(name);    //lucas  /*若使用let定义name变量则输出Dan,因为作用域,变量提升以及不能重复定义变量问题*/

 

4.函数命名以驼峰方式,首字母小写

不是命名规范中的,但是建议这么写。


与普通函数相比,构造函数有以下明显特点:

1.用new关键字调用

var person=new Person("lucas",22);

为了保证必须使用new命令和构造函数一起使用,可以在构造函数内部使用严格模式use strict,这样一旦忘记使用new,命令会报错。


2.函数内部可以使用this关键字

在构造函数内部,this指向的是构造出的新对象。用this定义的变量或函数/方法,就是实例变量或实例函数/方法。需要用实例才能访问到,不能用类型名访问。

person.name   //22
Person.name  //undefined


3.默认不用return返回值

构造函数是不需要用return显式返回值的,默认会返回this,也就是新的实例对象。当然,也可以用return语句,返回值会根据return值的类型而有所不同,细节将在下文介绍。


4.函数命名建议首字母大写,与普通函数区分开。

不是命名规范中的,但是方便区分和后期维护建议这么写。


用new关键字的时候到底做了什么

使用new关键字实例化的过程:

1.第一步,创建一个空对象。var prince={}
2.第二步,将构造函数Prince()中的this指向新创建的对象prince。
3.第三步,将prince的_proto_属性指向Prince函数的prototype,创建对象和原型间关系
4.第四步,执行构造函数Prince()内的代码。

构造函数有返回值怎么办

构造函数里没有显式调用return时,默认是返回this对象,也就是新创建的实例对象。
当构造函数里调用return时,分两种情况:

1.return的是五种简单数据类型:String,Number,Boolean,Null,Undefined。
这种情况下,忽视return值,依然返回this对象。

2.return的是Object
这种情况下,不再返回this对象,而是返回return语句的返回值。

function Person(name){
    this.name=name;
    return {name:"lucas"}
}
var person=new Person("Dan");
console.log(person.name);//lucas
console.log(person);//Object {name: "lucas"}

构造函数能当普通函数调用吗

构造函数可以作为普通函数使用,普通函数也可以作为构造函数来用。


链接: https://www.fly63.com/article/detial/4284

JavaScript 函数式编程

我理解的 JavaScript 函数式编程,都认为属于函数式编程的范畴,只要他们是以函数作为主要载体的。

Js函数式编程,给你的代码增加一点点函数式编程的特性

给你的代码增加一点点函数式编程的特性,最近我对函数式编程非常感兴趣。这个概念让我着迷:应用数学来增强抽象性和强制纯粹性,以避免副作用,并实现代码的良好可复用性。同时,函数式编程非常复杂。

让我们来创建一个JavaScript Wait函数

Async/await以及它底层promises的应用正在猛烈地冲击着JS的世界。在大多数客户端和JS服务端平台的支持下,回调编程已经成为过去的事情。当然,基于回调的编程很丑陋的。

JavaScript函数创建的细节

如果你曾经了解或编写过JavaScript,你可能已经注意到定义函数的方法有两种。即便是对编程语言有更多经验的人也很难理解这些差异。在这篇博客的第一部分,我们将深入探讨函数声明和函数表达式之间的差异。

编写小而美函数的艺术

随着软件应用的复杂度不断上升,为了确保应用稳定且易拓展,代码质量就变的越来越重要。不幸的是,包括我在内的几乎每个开发者在职业生涯中都会面对质量很差的代码。这些代码通常有以下特征:

javascript回调函数的理解和使用方法(callback)

在js开发中,程序代码是从上而下一条线执行的,但有时候我们需要等待一个操作结束后,再进行下一步操作,这个时候就需要用到回调函数。 在js中,函数也是对象,确切地说:函数是用Function()构造函数创建的Function对象。

js调用函数的几种方法_ES5/ES6的函数调用方式

这篇文章主要介绍ES5中函数的4种调用,在ES5中函数内容的this指向和调用方法有关。以及ES6中函数的调用,使用箭头函数,其中箭头函数的this是和定义时有关和调用无关。

JavaScript中函数的三种定义方法

函数的三种定义方法分别是:函数定义语句、函数直接量表达式和Function()构造函数的方法,下面依次介绍这几种方法具体怎么实现,在实际编程中,Function()构造函数很少用到,前两中定义方法使用比较普遍。

js在excel的编写_excel支持使用JavaScript自定义函数编写

微软 称excel就实现面向开发者的功能,也就是说我们不仅可以全新定义的公式,还可以重新定义excel的内置函数,现在Excel自定义函数增加了使用 JavaScript 编写的支持,下面就简单介绍下如何使用js来编写excel自定义函数。

js中的立即执行函数的写法,立即执行函数作用是什么?

这篇文章主要讲解:js立即执行函数是什么?js使用立即执行函数有什么作用呢?js立即执行函数的写法有哪些?

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!