1、定义函数
定义方式一
绝对值函数
function abs(x){
if(x>=0){
return x;
}else{
return -x;
}
}
上述abs()
函数的定义如下:
function
指出这是一个函数定义;abs
是函数的名称;(x)
括号内列出函数的参数,多个参数以,
分隔;{ ... }
之间的代码是函数体,可以包含若干语句,甚至可以没有任何语句。
注意:
函数体内部的语句在执行时,一旦执行到return
时,函数就执行完毕,并将结果返回。因此,函数内部通过条件判断和循环可以实现非常复杂的逻辑。
如果没有return
语句,函数执行完毕后也会返回结果,只是结果为undefined
。
定义方式二
var abs = function(x){
if(x>=0){
return x;
}else{
return -x;
}
};
注意:
在这种方式下,function (x) { ... }
是一个匿名函数,它没有函数名。但是,这个匿名函数赋值给了变量abs
,所以,通过变量abs
就可以调用该函数。
上述两种定义完全等价,注意第二种方式按照完整语法需要在函数体末尾加一个;
,表示赋值语句结束。
2、调用函数
调用函数时,按顺序传入参数即可
abs(10) //返回10
abs(-10) //返回9
参数问题:
- 由于JavaScript允许传入任意个参数而不影响调用,因此传入的参数比定义的参数多也没有问题,虽然函数内部并不需要这些参数:
abs(10, 'blablabla'); // 返回10
abs(-9, 'haha', 'hehe', null); // 返回9
- 传入的参数比定义的少也没有问题:
abs(); // 返回NaN
//此时abs(x)函数的参数x将收到undefined,计算结果为NaN。
- 要避免收到
undefined
,可以对参数进行检查:
function abs(x) {
if (typeof x !== 'number') {
throw 'Not a number';
}
if (x >= 0) {
return x;
} else {
return -x;
}
}
3、arguments
arguments
是一个JS免费赠送的关键字;代表,传递进来的所有的参数,是一个数组!
var abs = function(x){
console.log("x="+x);
for (var i = 0; i<arguments.length;i++){
console.log(arguments[i]);
}
if(x>=0){
return x;
}else{
return -x;
}
}
- 利用
arguments
,你可以获得调用者传入的所有参数。也就是说,即使函数不定义任何参数,还是可以拿到参数的值:
function abs() {
if (arguments.length === 0) {
return 0;
}
var x = arguments[0];
return x >= 0 ? x : -x;
}
abs(); // 0
abs(10); // 10
abs(-9); // 9
arguments
最常用于判断传入参数的个数。你可能会看到这样的写法:
// abs(a[, b], c)
// 接收2~3个参数,b是可选参数,如果只传2个参数,b默认为null:
function abs(a, b, c) {
if (arguments.length === 2) {
// 实际拿到的参数是a和b,c为undefined
c = b; // 把b赋给c
b = null; // b变为默认值
}
// ...
}
4、rest
ES6引入的新特性,获取除了已经定义的参数之外的所有参数!
旧版本写法:
function aaa(a,b) {
console.log("a=>"+a);
console.log("b=>"+b);
if (arguments.length>2){
for (var i = 2; i<arguments.length;i++){
//。。。。
}
}
}
ES6 引入的新特性,获取除了已经定义的参数之外的所有参数~ ….
function aaa(a,b,...rest) {
console.log("a="+a);
console.log("b="+b);
console.log(rest);
}
aaa(1, 2, 3, 4, 5);
// 结果:
// a = 1
// b = 2
// Array [ 3, 4, 5 ]
aaa(1)
// a = 1
// b = undefined
// Array []
注意:
-
rest 参数只能写在最后面,必须用 … 标识。
-
因为rest参数是ES6新标准,所以你需要测试一下浏览器是否支持。请用rest参数编写一个
sum()
函数,接收任意个参数并返回它们的和:
'use strict';
function sum(...rest) {
???
}
5、return
JavaScript引擎有一个在行末自动添加分号的机制,所以要注意return的用法
function foo() {
return { name: 'foo' };
}
foo(); // { name: 'foo' }
如果把return语句拆成两行:
function foo() {
return
{ name: 'foo' };
}
foo(); // undefined
问题:为什么会undefined?
由于JavaScript引擎有一个在行末自动添加分号的机制,上面的代码实际上变成了:
function foo() {
return; // 自动添加了分号,相当于return undefined;
{ name: 'foo' }; // 这行语句已经没法执行到了
}
所以正确多行写法是:
function foo() {
return { // 这里不会自动加分号,因为{表示语句尚未结束
name: 'foo'
};
}