js有三种创建函数的方式:

1.function语句(也叫函数声明)

  function sum(a, b) {
return a + b;
}
sum(1, 2); // 3

2. 函数直接量,又叫函数字面量

它是一个表达式而不是语句。

  var sum = function(a, b) {
return a + b;
}
sum(1, 2); // 3

上述代码就是函数通过直接量的方式进行定义。函数直接量是一个表达式,它可以定义匿名函数。函数直接量的语法和function语句十分相似,只不过, 它被用作表达式的一部分,而不是用作语句了。在函数直接量定义中,右侧的function所定义的是匿名函数,并将这个匿名函数的引用传递给表达式左侧。接下来执行了sum(1, 2),就运行了这个函数。

ps: 虽然函数字面量是一个匿名函数,但语法允许为其指定任意一个函数名,当写递归函数时可以调用它自己,使用Function()构造函数则不行。

var test = function factorial(x) {
if (x <= 1) {
return 1;
} else {
return x * factorial(x-1);
}
}; test(3); // 6
// 这个也是闭包的一种用法

3. 构造函数

它也是一个函数表达式。

  var sum = new Function('a', 'b', 'return a + b;');
sum(1, 2); // 3

比较区别

首先我们来看看1、2之间的区别:

大家都知道有这样一个原理:函数声明格式的函数存在函数声明提前,而函数表达式构造函数都不存在函数声明提前。

所以咱们的js解析器就会先读取函数声明格式的函数,让其在执行任何代码之前就可以访问;而函数表达式则必须要等到js解析器执行到它所在的位置的时候才会被真正执行。

自执行函数严格来说也叫函数表达式,它主要用于创建一个新的作用域,在此作用域内声明的变量,不会和其他作用域内的变量冲突或混淆,大多以匿名函数方式存在,并且立即自动执行。

  (function(a, b) {
console.log(a + b); // 3
})(1, 2) var sum=(function(a, b){
return a + b;
})(1, 2);
console.log(sum); // 3

接下来我们来看第三种方式:

  1. 采用new Funciton的方式,这样会导致解析器会解析两次代码(第一次是解析常规ECMAScript代码,第二次则是解析传入构造函数中的字符串),从而影响性能。一般我们很少用到。
  2. 我们来看一个闭包的三种函数实现的栗子:
  var a = 1;
function test1(){
var a = 2; // 局部变量
function test(){ return a; }; // function语句式,a=2
return test();
}
test1(); // 2
  var a = 1;
function test1(){
var a = 2; // 局部变量
var test = function(){ return a;}; // 函数直接量,a=2 ,两者都是函数的作用域
return test();
}
test1(); // 2
  var a = 1;
function test2(){
var a = 2; // 局部变量
var test = new Function("return a;"); // 构造函数,顶级的作用域,相当于在全局new一个函数,只能找到全局的a=1
return test();
}
test2(); // 1 没想到是1吧

用Function()构造函数创建一个函数时并不遵循典型的作用域,它一直把它当作是顶级函数来执行。顶级的作用域,相当于在全局new一个函数,只能找到全局的变量。

总结

最后用一张表格总结一下:

--- function语句 函数直接量 构造函数
创建形式 function f(){} var f = function(){} var f = new Function()
是否有名 有名字 匿名 匿名
性质 静态 静态 动态
解析机制 优先解析 顺序解析 顺序解析,且解析两次
性能 效率高 效率高 效率低
作用域 函数作用域 函数作用域 全局函数(具有顶级作用域),仅访问全局变量

动态和静态的区别function语句式 和 函数直接量 被javascript解释一次,放在了内存,以后用到的话直接调用,占用内存,所以说是“静态”的。而构造函数式是每一次调用都动态新建一个,用完之后就销毁了,不占用内存,所以说是“动态”的。所以,有些程序只希望调用一次,就可以用动态的构造函数式。

总结: js的三种创建方式都说完了,感觉讲还是比较清楚吧,参考学习了各方面的资料,这里加上自己的理解做了一次汇总。希望对自己也是一种提升。

转载自:
https://www.jscwwd.com/article/5e70976667f5cf03e3a5990b

更多前端文章在益码凭川博客网站

js函数的三种成创建方式以及它们各自的不同的更多相关文章

  1. js 函数定义三种方式

    <p>Js 函数定义的三种方式:</p> <br> <p>方式一:function</p> <script type="te ...

  2. JS函数的三种方式

    函数,一段能够自动完成某些功能的代码块,函数的出现,既解决了重复使用重一功能的需求,又可以避免代码的臃肿性. 使用函数有两个要求:必须调用后才可以执行;函数名不要和关键字以及系统函数相同; 函数主要有 ...

  3. 三种bean创建方式

  4. JavaScript创建函数的三种方式

    ㈠函数(function) ⑴函数也是一个对象 ⑵函数中可以封装一些功能(代码),在需要时可以执行这些功能(代码) ⑶函数中可以保存一些代码在需要的时候调用 ⑷使用typeof检查一个函数对象时,会返 ...

  5. js中的三种函数写法

    js中的三种函数写法 <script type="text/javascript"> //普通的声明方式 function myFun(m,n){ alert(m+n) ...

  6. JS高级---三种创建对象的方式

    JS高级---三种创建对象的方式 字面量的方式 (实例对象) 调用系统的构造函数 自定义构造函数方式 //创建对象---->实例化一个对象,的同时对属性进行初始化 var per=new Per ...

  7. 从壹开始前后端分离【 .NET Core2.0 +Vue2.0 】框架之十二 || 三种跨域方式比较,DTOs(数据传输对象)初探

    更新反馈 1.博友@落幕残情童鞋说到了,Nginx反向代理实现跨域,因为我目前还没有使用到,给忽略了,这次记录下,为下次补充.此坑已填 2.提示:跨域的姊妹篇——<三十三║ ⅖ 种方法实现完美跨 ...

  8. javascript中var let const三种变量声明方式

    javascript中var let const三种变量声明方式 1.var  ①var表示声明了一个变量,并且可以同时初始化该变量. ②使用var语句声明的变量的作用域是当前执行位置的上下文:一个函 ...

  9. Apache Spark探秘:三种分布式部署方式比较

    转自:链接地址: http://dongxicheng.org/framework-on-yarn/apache-spark-comparing-three-deploying-ways/     目 ...

随机推荐

  1. C# for循环提升效率的写法

    ,,,,,}; ,iLen=arr.Length;i<iLen;i++) //必须是显示申明,不能var { ........... }

  2. dotfuscator安装

    1.vs 2017 安装 dotfuscator 组件 打开vs 2017 按 ctrl + Q在输入框中输入“dotfuscator” ,选中第一个. 2.安装完成后即可在vs的工具中看到该组件 3 ...

  3. JS做深度学习3——数据结构

    最近在上海上班了,很久没有写博客了,闲下来继续关注和研究Tensorflow.js 关于深度学习的文章我也已经写了不少,部分早期作品可能包含了不少错误的认识,在后面的博文中会改进或重新审视. 今天聊聊 ...

  4. 题解:BZOJ 1009 HNOI2008 GT考试 KMP + 矩阵

    原题描述: 阿申准备报名参加GT考试,准考证号为N位数 X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字.他的不吉利数学A1A2...Am(0<=Ai&a ...

  5. 默认的Settings.xml文件(无修改过)-Maven

    Tip: 当什么都不作修改时,默认是从Maven中央仓库进行下载,https://repo.maven.apache.org/maven2. 打开maven源码下的lib文件夹,找到maven-mod ...

  6. 如何用js判断一个对象是不是Array

    .如何用js判断一个对象是不是Array 1.Array.isArray(obj) 调用数组的isArray方法 2.obj instanceof Array 判断对象是否是Array的实例 3.Ob ...

  7. AI能帮我们造出一个无肉的世界吗?

    AI听起来很遥远,其实已经渗透到我们的日常工作和生活中.在不远的未来,互联网.大数据.硬件的发展和软件的优化,乃至全社会的参与,人工智能将真正从实验室走进生活,它将成为改变我们生活的一部分.我们吃的肉 ...

  8. 在不重启MySQL的情况下用gdb工具设置变量

    前提:此方法只是参考其它博客的一个记录,未经亲自验证 当在mysql客户端设置一些变量时提示如下报错: 于是想能否有办法在不重启的情况下设置这些只读变量,在网上搜索别人的博客后发现如下方法 1.命令行 ...

  9. hexo创建新文章的正确方法

    起因 之前我一直是通过复制以前的文章的形式来创建一个新的文档,但是这一次似乎遇到了一些问题.我将文章写完之后,准备进行预览,输入hexo s命令.在预览页面却没有显示出新的文章,还是和之前的页面是一样 ...

  10. ES6中Map数据结构学习笔记

    很多东西就是要细细的品读然后做点读书笔记,心理才会踏实- Javascript对象本质上就是键值对的集合(Hash结构),但是键只能是字符串,这有一定的限制. 1234 var d = {}var e ...