JS学习之路(二)---函数
来源:互联网 发布:多益网络校招登录 编辑:程序博客网 时间:2024/05/22 05:10
函数的匿名定义
var abs = function (x) { if (x >= 0) { return x; } else { return -x; }};
function (x) { … }是一个匿名函数,它没有函数名。但是,这个匿名函数赋值给了变量abs,所以,通过变量abs就可以调用该函数
由于JavaScript允许传入任意个参数而不影响调用,因此传入的参数比定义的参数多或少也没有问题
arguments
JavaScript还有一个免费赠送的关键字arguments,它只在函数内部起作用,并且永远指向当前函数的调用者传入的所有参数。arguments类似Array但它不是一个Array:
function foo(x) { alert(x); // 10 for (var i=0; i<arguments.length; i++) { alert(arguments[i]); // 10, 20, 30 }}foo(10, 20, 30);
利用arguments,你可以获得调用者传入的所有参数。也就是说,即使函数不定义任何参数,还是可以拿到参数的值:
function abs() { if (arguments.length === 0) { return 0; } var x = arguments[0]; return x >= 0 ? x : -x;}abs(); // 0abs(10); // 10abs(-9); // 9
实际上arguments最常用于判断传入参数的个数。你可能会看到这样的写法:
// foo(a[, b], c)
// 接收2~3个参数,b是可选参数,如果只传2个参数,b默认为null:
function foo(a,b,c){ if (arguments.length === 2) { // 实际拿到的参数是a和b,c为undefined c = b; // 把b赋给c b = null; // b变为默认值 }}
rest参数
由于JavaScript函数允许接收任意个参数,于是我们就不得不用arguments来获取所有参数:
function foo(a, b) { var i, rest = []; if (arguments.length > 2) { for (i = 2; i<arguments.length; i++) { rest.push(arguments[i]); } } console.log('a = ' + a); console.log('b = ' + b); console.log(rest);}
为了获取除了已定义参数a、b之外的参数,我们不得不用arguments,并且循环要从索引2开始以便排除前两个参数,这种写法很别扭,只是为了获得额外的rest参数,有没有更好的方法?
ES6标准引入了rest参数,上面的函数可以改写为:
function foo(a, b, ...rest) { console.log('a = ' + a); console.log('b = ' + b); console.log(rest);}foo(1, 2, 3, 4, 5);// 结果:// a = 1// b = 2// Array [ 3, 4, 5 ]foo(1);// 结果:// a = 1// b = undefined// Array []
rest参数只能写在最后,前面用…标识,从运行结果可知,传入的参数先绑定a、b,多余的参数以数组形式交给变量rest,所以,不再需要arguments我们就获取了全部参数。
如果传入的参数连正常定义的参数都没填满,也不要紧,rest参数会接收一个空数组(注意不是undefined)。
小心你的return语句
前面我们讲到了JavaScript引擎有一个在行末自动添加分号的机制,这可能让你栽到return语句的一个大坑:
function foo() { return { name: 'foo' };}foo(); // { name: 'foo' }
如果把return语句拆成两行:
function foo() { return { name: 'foo' };}foo(); // undefined
要小心了,由于JavaScript引擎在行末自动添加分号的机制,上面的代码实际上变成了:
function foo() { return; // 自动添加了分号,相当于return undefined; { name: 'foo' }; // 这行语句已经没法执行到了}
所以正确的多行写法是:
function foo() { return { // 这里不会自动加分号,因为{表示语句尚未结束 name: 'foo' };}
- JS学习之路(二)---函数
- Js学习之路二 --- 初识函数
- js学习二函数
- JavaScript学习笔记之JS函数(二)
- JS学习之路(二)
- JS基础学习之 -- 函数
- js学习之parseInt()函数
- JS学习笔记之函数
- js继承之二-----借用构造函数
- node.js学习之路(二) 包的发布
- Node.js学习笔记之二:回调
- Js学习之路三 --- 函数传参
- Js学习之路四 --- 提取事件、匿名函数、数组
- Node.js学习教程之二:node.js的HelloWorld
- 【python学习】之二、函数式编程
- python 学习之二 函数篇
- Common Lisp学习之二:使用函数
- swift 学习之二(函数)
- 最大公约数和最小公倍数
- acrgis api for javaScript需要对Dojo了解多少?
- 存储过程实现开窗函数功能
- Quartz说明及使用
- keil编译出错关于__use_no_semihosting_swi的使用
- JS学习之路(二)---函数
- 常见机器学习算法
- LeetCode算法题目:Next Permutation
- Sphinx匹配模式详解
- JavaScript中return的用法详解
- ubuntu格式化优盘为fat32
- 常用shell (一)
- Android中Canvas绘图基础详解
- spring jpa CrudRepository save 新建数据没有返回id