JavaScript中的普通函数与构造函数比较
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JavaScript中的普通函数与构造函数比较,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3292字,纯文字阅读大概需要5分钟。
内容图文
![JavaScript中的普通函数与构造函数比较](/upload/InfoBanner/zyjiaocheng/755/e2b708ca4d394bea8feb5b4095dc2673.jpg)
想必学过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
构造函数与普通函数区别
这是一个简单的普通函数
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);
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语句的返回值。
<script> 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.jb51.net/article/63648.htm
内容总结
以上是互联网集市为您收集整理的JavaScript中的普通函数与构造函数比较全部内容,希望文章能够帮你解决JavaScript中的普通函数与构造函数比较所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。