1.函数的重要地位

函数(functions)在JavaScript里有着重要的地位,其原因有二:

  • 它们是一种特殊的对象
  • 它们提供作用域

说函数在JavaScript里是特殊的对象,因为:

  • 程序的执行时期可以动态创建函数对象;
  • 函数对象可以赋给变量,通过变量可以再传递给其它变量,还可以被删除;
  • 函数对象可作为其它函数的形参,也可以作为函数的返回值;
  • 函数对象可以有自己的属性和方法(methods)。

例如,(实际编程中完全可以这样做)对于JavaScript的函数A来说,它是个对象;它有自己的属性和方法,这个方法又是个函数,叫函数B;函数B接受另一个函数C作为形参,当B执行完后,返回一个新的函数D。这就是JavaScript函数的强大和灵活之处。
函数还可以使用它的构造函数Function,被new出来(但我们不推荐这么做):

// antipattern
// for demo purposes only
var add = new Function('a, b', 'return a + b');
add(1, 2); // returns 3

在上面的代码中,add是个对象,因为它是new操作的结果;但它又是个函数,因为它可以通过传递形参,执行计算任务。
说函数可以提供作用域,这
也很重要。因为在JavaScript里,两个成对的花括号并不像C程序那样提供局部的作用域,而在JavaScript里,只有函数才能提供类似的功
能。例如,在函数内部用var声明的变量都是局部变量,对外不可以见,类似于Java里的private属性。而在全局的if或for循环的花括号里,用
var声明的变量都是全局变量。
2. 关于函数的术语
JavaScript的函数很强大,所以我们有必要对它的使用方法给出统一的术语。比如下面的代码展示了一个“有名函数表达式”(named)

function expression):
// named function expression
var add = function add(a, b) {
return a + b;
};

如果上面的代码里略去函数的名字add(也就是第二个add),就变成了一个“匿名函数表达式”( unnamed function expression),也称为“匿名函数”(anonymous function)。

// function expression, a.k.a. anonymous function
var add = function (a, b) {
return a + b;
};

上面的两个例子,可以统称为“函数表达式”,而“有名函数表达式”只是函数表达式的一种特殊情况,事实上,声明时略去了函数的名字并不影响函数的定义以及后续的调用执行。如果声明时没有略去函数的名字,我们可以通过add.name得到它的名字,这对于程序调试时可能会有用。
另外,还有一种叫“函数声明”,它和函数表达式非常类似:

function foo() {
// function body goes here
}

语法上,“函数声明”,和“函数表达式”都是函数的字面声明法(Literal),它们的语法区别只在于后面的分号,而在使用上的区别只有在实际的程序中才能体现出来。那我们应选择使用哪一种声明法呢?如果作为形参或是对象中的方法,那没得选,只能使用函数表达式了:

// this is a function expression
// pased as an argument to the function `callMe`
callMe(function () {
// I am an unnamed function expression
// also known as an anonymous function
}); // this is a named function expression
callMe(function me() {
// I am a named function expression
// and my name is "me"
}); // another function expression
var myobject = {
say: function () {
// I am a function expression
}
};

一个函数声明和函数表达式在使用上的区别是声明上提的现象。比如,当在一个函数A里面进行函数B声明,不管函数B声明在哪里,都可以在A内部的任意位置调用;类似的,当一个函数A里执行函数B的表达式,只有在表达式后面的代码才可以调用函数B。下面的例子说明了这个问题:

// antipattern
// for illustration only // global functions
function foo() {
alert('global foo');
}
function bar() {
alert('global bar');
} function hoistMe() {
console.log(typeof foo); // "function"
console.log(typeof bar); // "undefined" foo(); // "local foo"
bar(); // TypeError: bar is not a function // function declaration:
// variable 'foo' and its implementation both get hoisted
alert('local foo');
} // function expression:
// only variable 'bar' gets hoisted
// not the implementation
var bar = function () {
alert('local bar');
};
}
hoistMe();

3. 函数的name属性
如果是声明的是有名的函数,则可以使用函数对象的name属性:

function foo() {} // declaration
var bar = function () {}; // expression
var baz = function baz() {}; // named expression foo.name; // "foo"
bar.name; // ""
baz.name; // "baz"

name属性在调试程序的时候使用,也可以在函数体内递归调用的时候使用。

JavaScript基础函数的声明(014)的更多相关文章

  1. JavaScript基础函数和词法分析以及常用的内置对象和使用方法(4)

    day52 参考:https://www.cnblogs.com/liwenzhou/p/8004649.html 函数 函数定义 JavaScript中的函数和Python中的非常类似,只是定义方式 ...

  2. JavaScript基础函数---李老师的

    <!DOCTYPE html><html><head>    <title>demo2html</title>    <meta ch ...

  3. Javascript基础 函数“重载”

    Javascript不像其他编程语言一样具有函数签名(什么是函数签名,简单的说就是说函数的接受参数类型和参数个数,也有人认为返回类型也应该包括.具体概念大家可以到网上查询). 所以Javascript ...

  4. JavaScript基础函数的属性:记忆模式(019)

    函数在Javascript里是有属性的,因为它们是一种特殊对象.事实上,就算是没有明确声明,函数在最初就已经包含了一些固有的属性,比如所有函数都length这个属性,它可以指出函数声明了多少个参数: ...

  5. JavaScript -基础- 函数与对象

    一.JavaScript三对象 1.分类方式一 1)ECMAScript JavaScript的ECMA规范 JS本身的对象 2)Dom 操作HTML相关 3)BOM游览器对象 游览器窗口对象,全局的 ...

  6. Javascript基础——函数

    一 函数的介绍 1.概念:由一堆代码按照一定的规则,组成实现了某个功能,通过函数自身或事件调用 函数的特点: 忽略细节:只关注其实现的功能,不关注内部构造: 重复使用:函数可以实现代码的重复利用: 选 ...

  7. JavaScript -基础- 函数与对象(二)String

    一.判断数据类型typeof与判断对象类型instanceof 1.typeof typeof只能判断基础数据类型,无法判断引用数据类型 <script> var s="hell ...

  8. Javascript基础--函数(Function对象)

    1.函数是一段可执行的代码,函数可多次调用,模块化管理. 2.使用function语句,function funName([arg1][,arg2]....[,argn]){代码块}.所有版本可用,一 ...

  9. JavaScript基础函数的配置对象Configuration Objects(020)

    配置对象通常用在API库的实现中,当程序中需要编写要多次的模块,也可以采用这种模式.这种模式的好处是接口明确,扩展方便.比如,一个 addPerson在设计的最初需要两个参数作为初始化时人的姓名: f ...

随机推荐

  1. Java实现 LeetCode 700 二叉搜索树中的搜索(遍历树)

    700. 二叉搜索树中的搜索 给定二叉搜索树(BST)的根节点和一个值. 你需要在BST中找到节点值等于给定值的节点. 返回以该节点为根的子树. 如果节点不存在,则返回 NULL. 例如, 给定二叉搜 ...

  2. Java实现 蓝桥杯 算法训练 约数个数

    算法提高 约数个数 时间限制:1.0s 内存限制:512.0MB 输入一个正整数N (1 样例输入 12 样例输出 6 样例说明 12的约数包括:1,2,3,4,6,12.共6个 import jav ...

  3. Java实现蓝桥杯模拟元音单词的验证

    问题描述 小明对类似于 hello 这种单词非常感兴趣,这种单词可以正好分为四段,第一段由一个或多个辅音字母组成,第二段由一个或多个元音字母组成,第三段由一个或多个辅音字母组成,第四段由一个或多个元音 ...

  4. Java实现 LeetCode 109 有序链表转换二叉搜索树

    109. 有序链表转换二叉搜索树 给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. ...

  5. Java实现荷兰国旗问题

    问题描述 现有n个红白蓝三种不同颜色的小球,乱序排列在一起,请通过两两交换任意两个球,使得从左至右的球依次为红球.白球.蓝球.这个问题之所以叫荷兰国旗,是因为将红白蓝三色的小球弄成条状物,并有序排列后 ...

  6. 什么是 JVM ?

    什么是 JVM ? 解析:不仅仅是基本概念,还有 JVM 的作用. 答:JVM,即 Java Virtual Machine,Java 虚拟机.它通过模拟一个计算机来达到一个计算机所具有的的计算功能. ...

  7. java实现第六届蓝桥杯格子中输出

    格子中输出 格子中输出 stringInGrid方法会在一个指定大小的格子中打印指定的字符串. 要求字符串在水平.垂直两个方向上都居中. 如果字符串太长,就截断. 如果不能恰好居中,可以稍稍偏左或者偏 ...

  8. 注解实现SpringCache自定义失效时间

    注解实现SpringCache自定义失效时间 SpringCache是一个很方便的缓存框架,但是官方提供的缓存的配置只有全局的缓存失效时间,没有针对某个命名空间做配置,因为工作上业务的关系需要针对某一 ...

  9. Postgresql DB安装和使用问题记录

    2.选择语言后提示: Error: There has been an error. Please put SELinux in permissive mode and then run instal ...

  10. Brainman(规律题)【数学思想】

    Brainman 题目链接(点击) Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 12942   Accepted: 650 ...