Javascript 语言系统--- 基础语法(2)

1.函数部份:参数、箭头函数

ES6中支持默认参数:

reset 参数:

r

如果把rest 参数拿到数组前边的话,输出报错:

总结:1. rest 参数之后不能再有其他参数(即只能是最后一个参数),否则会报错。

2. 函数的length属性不包括rest 参数:

(function(a) { }).length   //1 

(function(...a){}).length  //0

(function(a,...b) { }).length  //1

2 箭头函数:

只有一个参数的情况:

括号内没有参数的情况:

多条语句和多个参数的情况:

箭头函数扩展:

argument 实参列表:

argument(actual parameter)指的是函数调用时的实际参数。

也就是说,在箭头函数中不能使用arguments来进行实际的传递实参。

...rest 参数是一个真正的数组对象,可以代替arguments在箭头函数中进行实参的传递。

补充:  

ES6引入reset参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了。reset参数搭配的变量是一个数组,该变量将对于的参数放入数组中。如:

function add(...values) {
  let sum = 0;

  for (var val of values) {
    sum += val;
  }

  return sum;
}

add(2, 5, 3) // 10

上面代码的add函数是一个求和函数,利用 rest 参数,可以向该函数传入任意数目的参数。下面是一个 rest 参数代替arguments变量的例子。

// arguments变量的写法
function sortNumbers() {
  return Array.prototype.slice.call(arguments).sort();
}

// rest参数的写法
const sortNumbers = (...numbers) => numbers.sort();

上面代码的两种写法,比较后可以发现,rest 参数的写法更自然也更简洁。

arguments对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用Array.prototype.slice.call先将其转为数组。rest 参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。下面是一个利用 rest 参数改写数组push方法的例子。

function push(array, ...items) {
  items.forEach(function(item) {
    array.push(item);
    console.log(item);
  });
}

var a = [];
push(a, 1, 2, 3)

注意,rest 参数之后不能再有其他参数(即只能是最后一个参数),否则会报错。

// 报错
function f(a, ...b, c) {
  // ...
}

函数的length属性,不包括 rest 参数。

(function(a) {}).length  // 1
(function(...a) {}).length  // 0
(function(a, ...b) {}).length  // 1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值