JavaScript世界的一等公民 - 函数(一)
来源:互联网 发布:驾照模拟考试 软件 编辑:程序博客网 时间:2024/05/22 10:45
简介
在很多传统语言(C/C++/Java/C#等)中,函数都是作为一个二等公民存在,你只能用语言的关键字声明一个函数然后调用它,如果需要把函数作为参数传给另一个函数,或是赋值给一个本地变量,又或是作为返回值,就需要通过函数指针(function pointer)、代理(delegate)等特殊的方式周折一番。
而在JavaScript世界中函数却是一等公民,它不仅拥有一切传统函数的使用方式(声明和调用),而且可以做到像简单值一样赋值、传参、返回,这样的函数也称之为第一级函数(First-class Function)。不仅如此,JavaScript中的函数还充当了类的构造函数的作用,同时又是一个Function类的实例(instance)。这样的多重身份让JavaScript的函数变得非常重要。
一、JavaScript函数入门级
JavaScript函数像一般语言一样也是遵循先声明后使用的原则,函数名只能包含字母、数字、下划线或$,且不能以数字开头。函数常见的声明方式有以下两种:
// 直接声明函数myfunc
function myfunc(/* arguments */) {}// 把匿名函数赋值给本地变量myfuncvar myfunc = function(/* arguments */) {}
注意,上面两种函数声明方式存在细微的差别:第一种方式在声明时就是一个命名的函数,无论是声明在调用之前、调用之后,甚至是不会执行到的位置(例如return语句之后或是永远不会为真的分支里),都在整个作用域可访问;第二种方式是通过把匿名函数赋值给变量的方式,严格意义上说这不是一个函数的声明(function declaration)而是一个函数表达式(function expression),在赋值之前这个函数不能被任何代码访问到,也就是说这个赋值必须在调用之前完成,否则调用时会出现错误:"TypeError: undefined is not a function"。例如:
myfunc1(); // 能够正常调用,因为myfunc1采用直接声明的方式
function myfunc1() {
}
myfunc2(); // 出错 TypeError: undefined is not a function
var myfunc2 = function() {
};
函数的基本调用方式与传统语言相同用一对括号调用: myfunc()。JavaScript的函数也支持直接或间接的递归(recursive)调用,例如经典的斐波那契函数用JavaScript可以这样实现:
function fib(n) { if (n == 1 || n == 2) { return 1; } else { return fib(n - 2) + fib(n - 1); }}
在JavaScript的函数可以处理变长参数,在函数内部都拥有一个名为arguments的局部变量,它是一个类数组(array-liked)的对象,里面包含了所有调用时传入的参数,有length属性表示参数的个数。例如:
function test() { alert(arguments.length);}test(1); // 1test(1, 'a'); // 2test(true, [], {}); // 3
利用arguments可以实现类似C语言printf的功能,也可以用来实现方法的多态。
- JavaScript世界的一等公民 - 函数(一)
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数
- JavaScript世界的一等公民 - 函数ZZ
- JavaScript世界的一等公民 - 函数
- 转载:JavaScript世界的一等公民 - 函数
- Windows下编译OpenSSL for Ruby On Rails
- 提高网站访问速度的34条军规
- 断想
- 黑马程序员—日记说明
- web下spring自动创建ApplicationContext对象策略
- JavaScript世界的一等公民 - 函数(一)
- HDU 1057 题目很难懂。300题大关
- web.py datetime Invalid format string
- 分组密码算法分析,改进
- Windows环境下使用SSH访问GitHub
- 获取操作系统版本相信信息的多种方法
- 数据绑定控件[选择类型控件]、图像显示控件【哈哈、28号就可以回家啦、亲们回家过中秋节啦~!各位们都淡定点啊~!】
- android小经验 - Activity onActivityResult()没有被调用问题
- Ruby on Rails