美文网首页
三、JavaScript 函数

三、JavaScript 函数

作者: Castiel_Z | 来源:发表于2017-12-22 18:56 被阅读0次

函数是由这样的方式进行声明的:关键字 function、函数名、一组参数,以及置于括号中的待执行代码。

JavaScript 函数的基本语法是这样的:

function functionName(arg0, arg1, ... argN) {

    statements

}

1 arguments 对象

在函数代码中,使用特殊对象 arguments,开发者无需明确指出参数名,就能访问它们。由于arguments的特性,JavaScript的函数没有重载

代码

执行结果如下:

执行结果

2 Function 对象(类)

ECMAScript 的函数实际上是功能完整的对象。每个函数实际上都是Function类型的实例。Function 类可以表示开发者定义的任何函数。与其他引用类型一样具有属性和方法。函数名实际上是一个指向内存堆中某个函数对象的指针。

2.1 定义函数的方式

1) 函数声明

function sayHi(sName, sMessage) { alert("Hello " + sName + sMessage); }

2) 函数表达式

var sayHi = function (sName, sMessage) { alert("Hello " + sName + sMessage); }

定义了一个变量sum并将其初始化为一个函数,注意到function关键字后面并没有函数名,这是因为在使用函数表达式定义函数,没必要使用函数名,通过变量sum即可引用函数。还要注意函数末尾有个分号,就像声明其他变量一样。

3) new构造函数

虽然这种用法也是函数表达式,但该用法不推荐。因为这种语法会导致解析两次代码(第一次是解析常规的ECMAScript代码,第二次是解析传入构造函数中的字符串),影响性能

使用Function构造函数,构造函数可以接受任意数量的参数,但最后一个参数始终都被看成是函数体,前面的参数则枚举出了新函数的参数。

var sayHi = new Function("sName", "sMessage", "alert(\"Hello \" + sName + sMessage);");

2.2 Function 对象的 length 属性

函数属于引用类型,所以它们也有属性和方法

代码

3 闭包

3.1 概念:

官方解释:闭包,指的是词法表示包括不被计算的变量的函数,也就是说,函数可以使用函数之外定义的变量。

阮一峰:闭包就是能够读取其他函数内部变量的函数

在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。

所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。

样例一:

var iBaseNum = 10;

function addNum(iNum1, iNum2) {

    function doAdd() {

        return iNum1 + iNum2 + iBaseNum;

    }

    return doAdd();

}

这里,函数 addNum() 包括函数 doAdd() (闭包)。内部函数是一个闭包,因为它将获取外部函数的参数 iNum1 和 iNum2 以及全局变量 iBaseNum 的值。 addNum() 的最后一步调用了 doAdd(),把两个参数和全局变量相加,并返回它们的和。这里要掌握的重要概念是,doAdd() 函数根本不接受参数,它使用的值是从执行环境中获取的。

注:理解闭包先看  四、JavaScript 作用域与作用域链 

3.2 闭包的用途

1) 读取函数内部的变量

2)让这些变量的值始终保持在内存中。

在这段代码中,result实际上就是闭包f2函数。它一共运行了两次,第一次的值是999,第二次的值是1000。这证明了,函数f1中的局部变量n一直保存在内存中,并没有在f1调用后被自动清除。

为什么会这样呢?原因就在于f1是f2的父函数,而f2被赋给了一个全局变量,这导致f2始终在内存中,而f2的存在依赖于f1,因此f1也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage collection)回收

3.2 使用闭包的注意点

1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值

3.3 思考题

题一:

代码片段

题二:

代码片段

参考:

1  阮一峰:学习Javascript闭包(Closure)

相关文章

  • 学习笔记5-函数

    函数 JavaScript的核心,JavaScript的核心,JavaScript的核心,重要的事情说三遍 函数定...

  • JavaScript函数、this以及闭包

    JavaScript笔记(三) 函数 理解函数 Javascript函数的参数与大多数其他语言中的函数的参数不同。...

  • 「DOM 编程」JavaScript 动画

    JavaScript 动画实现方式JavaScript 动画三要素定时器常见动画动画函数 JavaScript 动...

  • 三、JavaScript 函数

    函数是由这样的方式进行声明的:关键字 function、函数名、一组参数,以及置于括号中的待执行代码。 JavaS...

  • JavaScript上下文

    JavaScript中有三种运行环境 全局环境:JavaScript最开始运行的默认环境 函数环境:函数执行时,函...

  • Javascript 函数缺省值

    Javascript 函数 Javascript 函数缺省值写法

  • JavaScript函数式编程

    读完《JavaScript函数式编程》《JavaScript函数式编程指南》这两本书,对JavaScript函数式...

  • JavaScript函数式编程

    读完《JavaScript函数式编程》《JavaScript函数式编程指南》这两本书,对JavaScript函数式...

  • JavaScript函数

    layout: posttitle: JavaScript函数tags: [JavaScript, 函数]auth...

  • JavaScript encodeURI() 函数

    JavaScript encodeURI() 函数 JavaScript 全局函数](https://www.ru...

网友评论

      本文标题:三、JavaScript 函数

      本文链接:https://www.haomeiwen.com/subject/gnrxgxtx.html