普通函数和构造函数的区别
Posted 奥雷迪尔
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了普通函数和构造函数的区别相关的知识,希望对你有一定的参考价值。
在命名规则上,构造函数一般是首字母大写,普通函数遵照小驼峰式命名法。
在函数调用的时候:
function fn() { }
构造函数:1. new fn( )
2 .构造函数内部会创建一个新的对象,即f的实例
3. 函数内部的this指向 新创建的f的实例
4. 默认的返回值是f的实例
普通函数:1. fn( )
2. 在调用函数的内部不会创建新的对象
3. 函数内部的this指向调用函数的对象(如果没有对象调用,默认是window)
4. 返回值由return语句决定
构造函数的返回值:
有一个默认的返回值,新创建的对象(实例);
当手动添加返回值后(return语句):
1. 返回值是基本数据类型-->真正的返回值还是那个新创建的对象(实例)
2. 返回值是复杂数据类型(对象)-->真正的返回值是这个对象
看一个常见的面试题
1 <script> 2 function foo() { 3 var f2 = new foo2(); 4 console.log(f2); //{a: 3} 5 console.log(this); //window 6 return true; 7 } 8 function foo2() { 9 console.log(this); //foo2类型的对象 不是foo2函数 10 // this.age = 30; 11 return {a: 3}; 12 } 13 var f1 = foo(); 14 console.log(f1); // true 15 </script>
以上是关于普通函数和构造函数的区别的主要内容,如果未能解决你的问题,请参考以下文章