一、设置默认参数

ES6之前,给函数设置默认参数是这样做的:

function fn(a) {
if(typeof y === undefined){
a = a || 'hello';
}
console.log(a);
}
fn('hi'); // 'hi'
fn(false); // false

这里之所以要判断一下,是因为我们本意是函数没有传值时才给参数 a 设置为 'hello',但是如果调用函数时传入了布尔值 false,也会把参数 a 设置为 'hello'

ES6 中允许为函数的参数设置默认值,直接写在参数的后面即可:

function fn(a = 'hello') {
console.log(a);
}
fn('hi'); // 'hi'
fn(false); // false

非常的简洁,严谨,不用判断,不过有一点需要注意,参数变量是默认声明的,所以,在函数体内,不能再使用 let 或者 const 再次声明:

function fn(a = 'hello') {
let a = 'hi'; // error
const a = 'ha'; // error
}

二、rest参数

ES6之前,获取函数多余的参数用的是 arguments:

function fn(a) {
for(var i = 0; i < arguments.length; i ++){
console.log(arguments[i]);
}
console.log(a);
}
fn(1, 2, 3);
//
//
//
//

而且这里 arguments 对象包括的是所有的参数,并不是严格意义上的多余的参数。

ES6 中,现在就可以使用 rest参数,用来完成获取多余的参数这件事了,很方便,语法为 ...变量名:

function fn(a, ...value) {
value.forEach(function (item) {
console.log(item);
});
}
fn(1, 2, 3);
//
//

函数体内,value 变量就是一个数组,包含传入的2个多余的参数 2、3

这里有一点需要注意,rest参数 只能放在最后面,不然就报错:

function fn(a, ...value, b) {   // error

}

 三、箭头函数

ES6允许使用箭头( => )来定义函数,这里定义一个最简单的函数:

var sayHi = () => {
alert('hi');
} // 等价于 function sayHi() {
alert('hi');
}

需要传参的话把参数写在圆括号里即可:

var add = (a, b) => {
console.log(a + b);
} //等同于 function add(a, b){
console.log(a + b);
}
add(10, 20); //

如果参数只有一个,也可以不使用圆括号:

var fn = a => {
console.log(a);
}
fn(100); //

而且如果只有一条语句,甚至花括号也可以省略。

var fn = a => console.log(a);
fn(100); //

这里还有一种极其简单的替代写法:

var fn = a => a;

// 等同于

var fn = function(a){
return a;
}
console.log(fn(10)); //

但是这种写法需要谨慎使用,比如返回的是一个对象就需要外面包一个圆括号,不然报错:

var fn = () => {username: 'tom', age: 24};   // error

// 需要这样才可以

var fn = () => ({username: 'tom', age: 24});

箭头函数有以下几个注意点:

  • 箭头函数中的 this,指的是定义时所在的对象,而不是调用时所在的对象。
  • 不可以当做构造函数,也就是说,不可以使用 new 操作符,否则报错。
  • 不可以使用 arguments对象

上面第一点,需要格外注意,因为它确定了箭头函数中的 this 的指向是不可变的:

var id = 10;
function fn() {
setTimeout(function () {
console.log(this.id);
},100)
}
fn.call({id: 20}); //

上面代码中,setTimeout 中的函数定义时在 fn函数 生成时,此时 this 是指向 {id: 20} 的,但它的真正执行却要等到100毫秒以后,这时 this 就指向了 window 了。如果我们非要改变这种情况,一般是这样做:

var id = 10;
function fn() {
var that = this;
setTimeout(function () {
console.log(that.id);
},100)
}
fn.call({id: 20}); //

现在在箭头函数中,直接写即可:

var id = 10;
function fn() {
setTimeout(() => {
console.log(this.id);
},100)
}
fn.call({id: 20}); //

由此可见,箭头函数是可以让 setTimeout 里面的 this,指向定义时所在的作用域,而不是调用时的作用域。

ES6中函数的扩展的更多相关文章

  1. es6(三):es6中函数的扩展(参数默认值、rest参数、箭头函数)

    1.函数可以设置参数默认值 function test1(x,y=1){ console.log(x,y) } test1(10)//10 1 2.rest参数:形式为...变量名 function ...

  2. ES6中函数新增的方式方法

    ---恢复内容开始---   绪 言 ES6 大家对JavaScript中的函数都不陌生.今天我就为大家带来ES6中关于函数的一些扩展方式和方法. 1.1函数形参的默认值 1.1.1基本用法 ES6 ...

  3. ES6中对象的扩展

    ES6不仅为字符串.数值和数组带来了扩展,也为对象带来了很多新特性.这一节,我们来一起学习一下对象的扩展. 对象的传统表示法 我们回顾一下,对象的传统表示法: let person = { " ...

  4. ES6 之 函数的扩展 尾调用以及尾递归

    函数参数的默认值 function log(x, y) { y = y || 'world' console.log(x + ' ' + y); } log('hello') // hello wor ...

  5. ES6中字符串的扩展

    一.查找字符串 在ES5中,可以使用 indexOf 方法和 lastIndexOf 方法查找字符串: let str = 'hello world'; alert(str.indexOf('o')) ...

  6. ES6入门——函数的扩展

    1.函数参数的默认值 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法.现在ES6可以为函数的参数添加默认值,简洁了许多. ES5 function show(a,b){ b = b ...

  7. 【ES6】函数的扩展

    1.函数参数默认值[详情例子参照ESMAScript 6入门 (阮一峰)] 允许为函数的参数设置默认值,即直接写在参数定义的后面.[例子1] 参数变量是默认声明的,所以不能用let或const再次声明 ...

  8. ES6中函数参数默认值问题

    参数默认值 // 以前的参数默认值写法 let fn = (a, b) => { a = typeof a === "undefined" ? 10 : a b = type ...

  9. 关于es6中对象的扩展

    1.Object.is() es5比较两个值是否相等,只有两个运算符,相等(==) 和 严格相等(===),他们都有缺点,前者会自动转换数据类型,后者的NaN不等于自身,以及+0 等于 -0.es6提 ...

随机推荐

  1. ElasticSearch 论坛搜索查询语句

    概述 研究论坛搜索如何综合时间和TF/IDF权重. 自定义权重计算的效率问题 数据结构 假设有一个论坛的搜索 字段包括: subject:标题 message:内容 dateline:发布时间 tag ...

  2. 机器人控制tcp通信参数调优

    机器人使用WiFi通信,实现指令下传,状态上传.而WiFi信道平时带宽较稳定,但会在某些时候突然中断,造成ping的延时较高,但可以马上恢复.如果一直ping,则一般情况下ping值很小,但长时间(数 ...

  3. [C++] OOP - Access Control and Class Scope

    Access Control And Inheritance Protected Member Like private, protected members are unaccessible to ...

  4. js如何处理字符串中带有↵字符

    js或vue中如何处理字符串中带有↵字符 split('\n') 使用split('\n')将字符串分割成数组就行 如果我们在vue中,只需要在页面中绑定变量时操作split('\n')就可以了: & ...

  5. css重修之书(一):如何用css制作比1px更细的边框

    如何用css制作比1px更细的边框 在项目的开发过程中,我们常常会使用到border:1px solid xxx,来对元素添加边框: 可是1px的border看起来还是粗了一些粗,不美观,那么有什么方 ...

  6. Zen Coding && Emmet-Sublime 安装

    Sublime Text 插件之:Emmet,旧版称:ex-Zen Coding 更名之后增加了CSS3和HTML5许多新特性.项目地址也从 code.google 移 github. 安装: Pac ...

  7. lintcode-182-删除数字

    182-删除数字 给出一个字符串 A, 表示一个 n 位正整数, 删除其中 k 位数字, 使得剩余的数字仍然按照原来的顺序排列产生一个新的正整数. 找到删除 k 个数字之后的最小正整数. N < ...

  8. OSG学习:使用已有回调示例

    回调的类型有很多种,一般很容易就想到的是UpdateCallBack,或者EventCallBack,回调的意思就是说,你可以规定在某件事情发生时启动一个函数,这个函数可能做一些事情.这个函数就叫做回 ...

  9. Linux系统的性能测试

    性能测试:CPU内存,硬盘IO读写,带宽速度,UnixBench 一.CPU物理个数.内核.超线程.多核心 1.登录Terminal,执行:cat /proc/cpuinfo,就会显示出主机的CPU详 ...

  10. chrome extension demos

    chrome extension demos demo https://github.com/hartleybrody/buzzkill/blob/master/bootstrap.js https: ...