es6笔记4^_^function
一、function默认参数
现在可以在定义函数的时候指定参数的默认值了,而不用像以前那样通过逻辑或操作符来达到目的了。
es5
function sayHello(name){
        //传统的指定默认参数的方式
        let name1 = name||'hubwiz';
        return 'Hello'+name1;
    }
运用ES6的默认参数
function sayHello2(name='hubwiz'){
        return `Hello ${name}`;
    }
    function sayHello3(name='张三',age=19){
       return `大家好,我叫${name},今年${age}岁`+'\n' +"大家好,我叫"+name+",今年"+age;
    }
  console.log(sayHello());//输出:Hello hubwiz
    console.log(sayHello('汇智网')); //输出:Hello 汇智网
    console.log(sayHello2());  //输出:Hello hubwiz
    console.log(sayHello2('汇智网'));
    console.log(sayHello3());//输出:Hello 汇智网
    console.log(sayHello3('nick',26));
二、rest参数
rest参数(形式为“...变量名”)可以称为不定参数,用于获取函数的多余参数,这样就不需要使用arguments对象了。
rest参数搭配的变量是一个数组,该变量将多余的参数放入数组中。
function add(...values) {
    console.log(...values);//1 2 3
    console.log(values);//[1,2,3]
    let sum = 0;
    for (var val of values) {
        sum += val;
    }
    return sum;
}
console.log(add(1, 2, 3));
不定参数的格式是三个句点后跟代表所有不定参数的变量名。比如以上示例中,...values 代表了所有传入add函数的参数。
三、扩展运算符
扩展运算符(spread)是三个点(...)。它好比rest参数的逆运算,将一个数组转为用逗号分隔的参数序列。该运算符主要用于函数调用。
它允许传递数组或者类数组直接做为函数的参数而不用通过apply。
let people=['张三','李四','王五'];
//sayHello函数本来接收三个单独的参数people1,people2和people3
function sayHello4(people1,people2,people3){
console.log(`Hello ${people1},${people2},${people3}`);
}
//但是我们将一个数组以拓展参数的形式传递,它能很好地映射到每个单独的参数
sayHello4(...people); //输出:Hello 张三,李四,王五
//而在es5,如果需要传递数组当参数,我们需要使用函数的apply方法
sayHello4.apply(null,people); //输出:Hello 张三,李四,王五
四、箭头函数
箭头函数是使用=>语法的函数简写形式。这在语法上与 C#、Java 8 和 CoffeeScript 的相关特性非常相似
let array = [1, 2, 3];
//传统写法
array.forEach(function(v) {
console.log(v);
});
//ES6
array.forEach(v => console.log(v));
//它们同时支持表达式体和语句体。与(普通的)函数所不同的是,箭头函数和其上下文中的代码共享同一个具有词法作用域的this。
let evens = [1,2,3,4,5];
let fives = [];
// 表达式体
let odds = evens.map(v => v + 1);
let nums = evens.map((v, i) => v + i);
let pairs = evens.map(v => ({even: v, odd: v + 1})); // 语句体
nums.forEach(v => {
if (v % 5 === 0){
fives.push(v);
}
});
console.log(fives);
具有词法作用域的 this
    let bob = {
        _name: "NICK",
        _friends: ["Amy", "Bob", "Cinne", "Dylan", "Ellen"],
        printFriends() {
            this._friends.forEach(f => console.log(this._name + " knows " + f));
        }
    }
    bob.printFriends();
例子:
es6
let test = (x, y) => {x++; y--; return x+y};
相当于es5
function test(x, y) {
    x++;
    y--;
    return x + y;
}
this问题
class Animal {
    constructor(){
        this.type = 'animal'
    }
    says(say){
        setTimeout(function(){
            console.log(this.type + ' says ' + say)
        }, 1000)
    }
}
var animal = new Animal()
animal.says('hi')  //undefined says hi
运行上面的代码会报错,这是因为setTimeout中的this指向的是全局对象。所以为了让它能够正确的运行,传统的解决方法有两种:
第一种是将this传给self,再用self来指代this
function says(say) {
    var self = this;
    setTimeout(function () {
        console.log(self.type + ' says ' + say)
    }, 1000)
}
第二种方法是用bind(this),即
    function says(say){
        setTimeout(function(){
            console.log(this.type + ' says ' + say)
        }.bind(this), 1000)
    }
但现在我们有了箭头函数,就不需要这么麻烦了:
class Animal2 {
    constructor(){
        this.type = 'animal'
    }
    says(say){
        setTimeout( () => {console.log(this);
            console.log(this.type + ' says ' + say)
        }, 1000)
    }
}
    var animal2 = new Animal2();
    animal2.says('hi') ; //animal says hi
箭头函数有几个使用注意点。
1.函数体内的this对象,即绑定定义时所在的对象,而不是使用时所在的对象。
并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,它的this是继承外面的,因此内部的this就是外层代码块的this。
2.不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。
3.不可以使用arguments对象,该对象在函数体内不存在。
上面三点中,第一点尤其值得注意。this对象的指向是可变的,但是在箭头函数中,它是固定的。
此篇终,待续……
es6笔记4^_^function的更多相关文章
- ES6笔记(5)-- Generator生成器函数
		系列文章 -- ES6笔记系列 接触过Ajax请求的会遇到过异步调用的问题,为了保证调用顺序的正确性,一般我们会在回调函数中调用,也有用到一些新的解决方案如Promise相关的技术. 在异步编程中,还 ... 
- ES6笔记系列
		ES6,即ECMAScript 6.0,ES6的第一个版本是在2015年发布的,所以又称作ECMAScript 2015 如今距ES6发布已经一年多的时间,这时候才去学,作为一个JSer,羞愧羞愧,还 ... 
- ES6笔记(1) -- 环境配置支持
		系列文章 -- ES6笔记系列 虽然ES6已经发布一年多了,但在各大浏览器之中的支持度还不是很理想,在这查看ES6新特性支持度 Chrome的最新版本浏览器大部分已经支持,在Node.js环境上支持度 ... 
- ES6笔记(2)-- let的块级作用域
		系列文章 -- ES6笔记系列 一.函数级作用域 我们都知道,在ES6以前,JS只有函数级作用域,没有块级作用域这个概念 没有块级作用域,有利有弊,利于方便自由,弊于作用域内的变量容易被共享,例如这个 ... 
- ES6笔记(3)-- 解构赋值
		系列文章 -- ES6笔记系列 解构赋值,即对某种结构进行解析,然后将解析出来的值赋值给相关的变量,常见的有数组.对象.字符串的解构赋值等 一.数组的解构赋值 function ids() { ret ... 
- ES6笔记(4)-- Symbol类型
		系列文章 -- ES6笔记系列 Symbol是什么?中文意思是标志.记号,顾名思义,它可以用了做记号. 是的,它是一种标记的方法,被ES6引入作为一种新的数据类型,表示独一无二的值. 由此,JS的数据 ... 
- ES6笔记(6)-- Set、Map结构和Iterator迭代器
		系列文章 -- ES6笔记系列 搞ES6的人也是够无聊,把JS弄得越来越像Java.C++,连Iterator迭代器.Set集合.Map结构都出来了,不知道说什么好... 一.简单使用 1. iter ... 
- ES6笔记(7)-- Promise异步编程
		系列文章 -- ES6笔记系列 很久很久以前,在做Node.js聊天室,使用MongoDB数据服务的时候就遇到了多重回调嵌套导致代码混乱的问题. JS异步编程有利有弊,Promise的出现,改善了这一 ... 
- ES6 笔记汇总
		ES6 笔记汇总 二.ES6基础-let和const命令 三.变量的解构赋值 四.字符串的拓展 五.正则表达式的拓展 ...将会持续更新,敬请期待 
- ES6笔记2
		ES6笔记2 Promise Promise 是 ES6 引入的异步编程的新解决方案,语法上是一个构造函数 一共有3种状态,pending(进行中).fulfilled(已成功)和rejected(已 ... 
随机推荐
- iOS 帧动画之翻转和旋转动画
			记录两个比较简单的动画,一个是翻转的动画,一个是旋转的动画. 旋转动画: 1 [UIView animateWithDuration:3 animations:^{ if (formView) { f ... 
- VC MFC工具栏(CToolBar)控件(转)
			工具栏 工具栏控件在控件面板里没有对应的选项(图标),但有一个工具栏控件类CToolBar,所以我们如果要创建一个工具栏控件并显示在窗口里的话,只能用代码来完成,事实上任何一种控件,都可以用代码创建, ... 
- 课时56.marquee标签(理解)
			这个标签是比较特殊的,不是html5中的新增标签 在W3C官方文档中找不到这个标签,也就是说不是官方推荐的标签 但是各大浏览器对这个标签的支持也非常不错,而且效果也非常不错 1.什么是marquee标 ... 
- bootstrap-01-学习记录
			1.bootstrap所有插件依赖JQ,必须在JQ之后引入. 2.bootstrap分预编译版(css,js,fonts)和源码版(less,js,fonts,dist->预编译版内容,docs ... 
- Spark_安装配置_运行模式
			一.Spark支持的安装模式: 1.伪分布式(一台机器即可) 2.全分布式(至少需要3台机器) 二.Spark的安装配置 1.准备工作 安装Linux和JDK1.8 配置Linux:关闭防火墙.主机名 ... 
- Python-变量与基础数据类型
			·变量(variable) 笔记: 变量本质上是一个占位符.变量可以用来存储整数.字符串.列表等.简单的可以理解为一个座位,可以坐老人也可以坐小孩,可以坐男孩,也可以坐女孩. 在python里,标识 ... 
- 中国大学MOOC-C程序设计(浙大翁恺)—— 素数和
			题目内容: 我们认为2是第一个素数,3是第二个素数,5是第三个素数,依次类推. 现在,给定两个整数n和m,0<n<=m<=200,你的程序要计算第n个素数到第m个素数之间所有的素数的 ... 
- go内建容器-切片
			1.基础定义 看到'切片'二字,满脸懵逼.切的啥?用的什么刀法切?得到的切片有什么特点?可以对切片进行什么操作? 先看怎么得到切片,也就是前两个问题.切片的底层是数组,所以切片切的是数组:切的时候采用 ... 
- Go 问题集
			删除文件后缀名,出现问题 import "strings" func changePath(file_path string) string { ) } 转换路径 /转换为\\ i ... 
- 20145209刘一阳《JAVA程序设计》第1周学习总结
			20145209刘一阳<JAVA程序设计>第1周学习总结 本周任务 了解Java基础知识 了解JVM.JRE与JDK,并下载.安装.测试JDK 了解PATH.CLASSPATH.SOURC ... 
