ES6总结(let,const,变量解构,模板字符串,对象简写,箭头函数,三点运算,形参默认值)

一、let和const关键字:

ES6声明变量就是防止变量在未声明时使用,如果在变量未声明之前使用就会报错

let作用:与var类似,用于声明一个变量

特点:在块作用域内有效、不能重复声明、不会预处理,不存在变量提升

应用:循环遍历加监听

const作用:定义一个常量

特点:不能修改、其它特点同let

应用:保存不用改变的数据

二、变量的解构赋值:

解构就是先解析你的结构然后再进行赋值,从对象或数组中提取数据,并赋值给变量(多个),你要的东西都得是对象或者数组里面有的属性名,属性名可以不用全部都要。

对象的解构赋值:

let {n,a}={n:'gmx',a:18}

那么n拿到的就是gmx,a拿到的就是18,如果你这样拿:let{n,x}={n:'gmx',a:18},就会拿到一个undefined,因为对象里面没有x这个属性名,你要的东西我没有,我就undefined,你可以少拿也可以全拿,但是你不能拿我没有的东西,就这样很简单。

数组的解构赋值:

let[a,b]=[1,'gmx']

a拿到的是1,b拿到的是gmx,数组解构赋值其实就是根据你所占的位置去拿对应的值,a在数组里面对应的下标为0,那么1的也是0,所以a拿到的就是1。

数组还可以这样:

let  arr=[1,2,4,5,'abc','bdg'];  //我就想拿字符串怎么办?

let [,,,,a,b]=arr;     //这样就可以了,多加4个逗号就是多占4个位置,相当于前4个我不要,我就要后2个。

应用:

funtion foo(obj){

       console.log(obj.name,obj.age);    

上面函数可以写成下面这种形式:

function foo({name,age}){  //{name,age}=obj

     console.log(name,age);

}

相当于在接收参数这个过程中就已经进行过一次解构赋值了,可以直接使用。

三、模板字符串:

模板字符串的作用:简化字符串的拼接

模板字符串必须用``包含

变化的部分使用${xxx}定义

例:

let obj={username:'gmx',age:18};

let str='我的名字叫:'+obj.username+',我今年的年龄是:'+obj.age;    //以前字符串拼接

str=`我的名字叫:${obj.username},我今年的年龄是:${obj.age}`;   //现在模板字符串

//两种输出是一样的,但是第二种模板字符串比第一种编写起来效率要高,不容易出错

四、对象的简写方式:

简化的对象写法:省略同名的属性值、省略方法的function

以前的写法:

let username='gmx';

let age=18;

let obj={

     username:username,

     age:age,

     getName:function(){

          return this.username;

   }

}

现在简化后:

let username='gmx';

let age=18;

let obj={

    username,   //同名属性可以省略不写

    age,

     getName(){    //可把:function省略不写

          return this.username;

}

}

以上两种方法输出的obj和obj.getName()是一样的,只是同名属性才可省略不写。

五、箭头函数详解:

作用:定义匿名函数

箭头函数的特点:

简洁

箭头函数没有自己的this,箭头函数的this不是调用的时候决定的,而是在定义的时候处在的对象就是它的this

扩展理解:箭头函数的this看外层的是否有函数,如果有,外层函数的this就是内部箭头函数的this,如果没有,则this是window。

基本语法:

没有参数:() => console.log('xxx')

let fun=function(){console.log("我是箭头函数")}

可写成:let fun=() =>console.log("我是箭头函数");

一个参数:i => i+1

let  fun=function(a){console.log(a)}

可写成:let  fun= a =>console.log(a);  //只有一个形参的时候,()可要省略

大于一个参数:(i,j) => i+j

let  fun=function(x,y){console.log(x,y)}

可写成:let  fun=(x,y)=>console.log(x,y); //当两个以及两个以上的形参的时候 ()不能省略

函数体不用大括号:默认返回结果

函数体只有一条语句或者表达式的时候,{}可以省略----》省略会自动返回语句执行的结果或者是表达式的结果

let fun=(x,y)=>x+y;

console.log(fun(20,30)); //结果为50

注意:如果以上x+y表达式加上{}后,会输出undefined,如果非得有值要返出去,就得{return x+y}这样子了。

函数体如果有多个语句,需要用{}包围,{}不可以省略,若有需要返回的内容,需要手动返回

let  fun=(x,y) => {

      console.log(x,y);

      return x+y;   //需要返回的内容必须手动返回

}

使用场景:多用来定义回调函数

测试箭头函数的this:

let btn1=document.getElementById("btn1");

let btn2=document.getElementById("btn2");

btn1.onclick=function(){

    alert(this);  //输出按钮对象

}

btn2.onclick=()=>{

alert(this); //输出window对象,它外层没函数所以this就是window,如果外层有函数,那么this就和外层函数的this一样

}

坑:

let obj={

  name:'箭头函数',

  getName:() => {

     btn2.onclick= () => {

        console.log(this);  //this是window对象,因为内层箭头函数会看自己外层有没有函数,一看,外层居然也是一个箭头函数,靠 不住了,然后外层箭头函数说,兄弟别走,我带你去找函数,结果都没找着函数,所以都指向window了。

                  }

        }

}

六、三点运算符

rest(可变)参数

用来取代arguments,但比arguments灵活,只能是最后部分形参参数

使用arguments:

function foo(a,b) {

  console.log(arguments);

}

foo(3,4);

arguments.callee()指函数本身。

如果使用数组方法forEach去遍历伪数组arguments:

function foo(a,b) {

  // console.log(arguments);

  arguments.forEach(function (item, index) {

    console.log(item,index);

  })

}

foo(3,4);

这样就会报错,因为arguments是伪数组,不具备数组的一般方法。

这时候,ES6就提出了一个点点点运算符,看下面:

function foo(...value) {  //三个点是它的特征

  console.log(arguments);  //伪数组

  console.log(value);  //真数组,输出时就不用写...

}

foo(3,4);

结果如下:

所谓真数组,也就能使用数组的所有方法了,那么forEach就不会报错了。

再比如:

function foo(a,...value) {  //此时a作为一个占位符,将带走一个实参,value就表示剩余部分的数组元素

  console.log(a);  //3

  console.log(value);  //[4,5,6,7]

}

foo(3,4,5,6,7);

如果这样就会报错:

function foo(a,...value,b) { //...value只能放在当前最后位置,所以这样写是会报错的

  console.log(a);

  console.log(value);

  console.log(b);

}

foo(3,4,5,6,7);

实例:

let arr=[1,3,5];

let arr1=[2,...arr,6]; //...arr代表[1,3,5],此时arr1为[2,1,3,5,6]

arr1.push(...arr);    //此时arr1为[2,1,3,5,6,1,3,5]

console.log(arr1)  //[2,1,3,5,6,1,3,5]

七、形参默认值

先来一个实例:

// 定义一个点的坐标

function point(x,y) {

  this.x=x;

  this.y=y;

}

let point1=new point(4,5);

console.log(point1);  //point {x: 4, y: 5}

如果在new的时候忘记传参了:

let point2=new point();

console.log(point2);  //point {x: undefined, y: undefined}

此时,就会出现Undefined,那么就想如果传参就指定我传的参数值,如果我不传参,就指定默认值。

// 定义一个点的坐标

function point(x=0,y=0) {

  this.x=x;

  this.y=y;

}

let point1=new point(4,5);

console.log(point1);  //point {x: 4, y: 5}

let point2=new point();

console.log(point2);  //point {x: 0, y: 0}

这就是形参默认值,你指定值,那么就是你的值,你不指定值,那么就用我默认的。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,233评论 6 495
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,357评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,831评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,313评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,417评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,470评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,482评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,265评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,708评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,997评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,176评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,503评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,150评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,391评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,034评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,063评论 2 352

推荐阅读更多精彩内容