ES6新增的方法有哪些


(1)let

區(qū)別1:

let定義的變量只能在代碼塊{}里面使用,形成一個{}塊級作用域

var作用于函數(shù)作用域

區(qū)別2:

let不允許重復聲明,它是一個封閉空間,解決了i問題

var a=5

var a=12 //-->a=5

let a=5

let a=12 //-->error

區(qū)別3:

const

const用來定義常量,一旦定義了,后面就不能修改了

(2)箭頭函數(shù)=>

*function()中this是指向調(diào)用這個函數(shù)的對象

箭頭函數(shù)中,this指向了window

arguments,不能使用

由于this在箭頭函數(shù)中已經(jīng)按照詞法作用域綁定了,所以实蔽,用call()或者apply()調(diào)用箭頭函數(shù)時男应,無法對this進行綁定鹅经,即傳入的第一個參數(shù)被忽略

(3)解構(gòu)賦值

左右兩邊結(jié)構(gòu)一樣

右邊必須是合法結(jié)構(gòu)(錯誤例子:{12,5,8})

聲明和賦值寫在一句話中(錯誤例子:let [a,b]; [a,b]=[12,5];)

//數(shù)組

let [a,b,c]=[12,5,101] // a=12,b=5,c=101

//JSON

let {a,b,c}={b:5,a:12,c:101} // json跟順序無關(guān),a=12,b=5,c=101

//混合型,左右結(jié)構(gòu)陕习、順序一致

let [{a,b},[n1,n2,n3],num,str] = [{a:12,b:5},[12,5,8],8,'EcmaScript']

//a=3,b=8,c is not defined? ? 對數(shù)組的解構(gòu)

var [a,b]=[3,5,8];

//x=V,y=u,z=e? ? 對字符串的結(jié)構(gòu)

var [x,y,z]=Vue;

//m=10,n=20? ? 對象的解構(gòu),對key進行拆分

var {n,m}={m:10,n:20};

(4)復制數(shù)組

var arr1=[1,2,3,4]

for(var i=0;i<arr1.length;i++){

? ? arr2[i]=arr1[i]

}

arr2=Array.from(arr1)

(5)JSON

//簡寫誉帅,當key,value一樣時,可以只寫一個

{m:m,n:n}--->{m,n}

//其中也可以有key闸餐、value不相同的

let a=12;

let b=5;

let json={a,b,c:8};? //{a:a,b:b,c:8}

console.log(json);? //{a:12,b:5,c:8}

//JSON里的方法簡寫,`:function`可以省略

let json={

? a:12,

? show(){? //show:function(){

? ? alert(this.a)

? }

}

(6)字符串模板?``(反單引號)

用于字符串連接矾芙,可以換行

`string text ${expression} string text`

(7)rest參數(shù)...(3個點)

var [x,...y]=[4,8,10,30] //x=4,y=[8,10,30] y成了動態(tài)參數(shù)

? let xy=[...'es6'];? //['e','s','6']? 拆解

? //數(shù)組拆分

? console.log(...[4,8])? //4,8

? //數(shù)組拆分的進階

? let arr1 =[1,3];let arr2=[4,8];

? [...arr1,...arr2]? //[1,3,4,8]

(8)默認參數(shù)

function show(a,b=5,c=12){

? console.log(a,b,c);

}

show(99,19)? ? //99,19,12

show(99)? ? //99,5,12

(9)for of循環(huán)

//for in

var arr=['apple','banana','orange','pear']

for(var i in arr){

? ? console.log(i); // for in 出來的是 索引0 1 2 3

}

//for of

var arr=['apple','banana','orange','pear']

for(var i of arr){

? ? console.log.(i); // for of 出來的是 實際apple,banana等

}

for of可以循環(huán)數(shù)組,但是不能循環(huán)json,因為它是為了與map配合使用

(10)Map(數(shù)據(jù)結(jié)構(gòu))

與for of配合使用近上,是一個key剔宪、value

var map = new Map();

map.set(name,value); // 可以設置name,value

map.get(name); // 可以單獨獲取name

map.delete(name); // 可以單獨刪除name

//與for of 的配合

for(var name of map){

? ? console.log(name);? // a,apple? b,banana

}

for(var [key,value] of map){

? ? console.log(key,value); // key,value

}

for(var key of map.keys) // 可以只循環(huán)map中的key值

(11)map(數(shù)組)

映射–原數(shù)組映射成新數(shù)組,一個對應一個

//例一

? let arr=[12,5,8];

? ? let result=arr.map(item=>item*2);

? ? alert(result);

//例二

? ? let score=[19, 85, 99, 25, 90];

? ? let result=score.map(item=>item>=60?'及格':'不及格');

? ? alert(score);

? ? alert(result);

(12)reduce(數(shù)組)

匯總–求和–多個變成一個

//求和

let arr=[12,69,180,8763];

? ? let result=arr.reduce(function (tmp, item, index){

? ? ? //alert(tmp+','+item+','+index);

? ? ? return tmp+item;

? ? });

? ? alert(result);

//求平均數(shù)

let arr=[12,69,180,8763];

? ? let result=arr.reduce(function (tmp, item, index){

? ? ? if(index!=arr.length-1){ //不是最后一次

? ? ? ? return tmp+item;

? ? ? }else{? ? ? ? ? ? ? ? ? ? //最后一次

? ? ? ? return (tmp+item)/arr.length;

? ? ? }

? ? });

? ? alert(result);

(13)filter(數(shù)組)

過濾器

let arr=[12,5,8,99,27,36,75,11];

? ? //選擇能夠被3整除的數(shù)

? ? let result=arr.filter(item=>item%3==0);

? ? alert(result);

(14)forEach(數(shù)組)

循環(huán)–迭代

let arr=[12,5,8,9];

? ? arr.forEach((item,index)=>{

? ? ? alert(index+': '+item);

? ? });

(15)面向?qū)ο骳lass

使用了class關(guān)鍵字壹无,現(xiàn)在構(gòu)造函數(shù)和類分開了

class里面直接加方法

//old

? ? function User(name, pass){

? ? ? this.name=name;

? ? ? this.pass=pass;

? ? }

? ? User.prototype.showName=function (){

? ? ? alert(this.name);

? ? };

? ? User.prototype.showPass=function (){

? ? ? alert(this.pass);

? ? };

//ES6

? ? class User{

? ? ? constructor(name, pass){

? ? ? ? this.name=name;

? ? ? ? this.pass=pass;

? ? ? }

? ? ? showName(){

? ? ? ? alert(this.name);

? ? ? }

? ? ? showPass(){

? ? ? ? alert(this.pass);

? ? ? }

? ? }

(16)繼承extends

old:?子類.prototype = new 父類

ES6:?class 子類 extends 父類{}

supper關(guān)鍵字:超類葱绒、父類

//old

function VipUser(name, pass, level){

? ? ? User.call(this, name, pass);

? ? ? this.level=level;

? ? }

? ? VipUser.prototype=new User();

? ? VipUser.prototype.constructor=VipUser;

? ? VipUser.prototype.showLevel=function (){

? ? ? alert(this.level);

? ? };

//ES6? ?

class VipUser extends User{

? ? ? constructor(name, pass, level){

? ? ? ? super(name, pass);

? ? ? ? this.level=level;

? ? ? }

? ? ? showLevel(){

? ? ? ? alert(this.level);

? ? ? }

? ? }

(17)模塊化

exprot default?// 導出

import modA from './a.js'?// 引入模塊


原文鏈接:https://blog.csdn.net/wsymcxy/article/details/82913756? 這個大佬寫的太全了。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末斗锭,一起剝皮案震驚了整個濱河市地淀,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌岖是,老刑警劉巖帮毁,帶你破解...
    沈念sama閱讀 218,546評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異豺撑,居然都是意外死亡烈疚,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評論 3 395
  • 文/潘曉璐 我一進店門聪轿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爷肝,“玉大人,你說我怎么就攤上這事〉婆祝” “怎么了金赦?”我有些...
    開封第一講書人閱讀 164,911評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長对嚼。 經(jīng)常有香客問我夹抗,道長,這世上最難降的妖魔是什么猪半? 我笑而不...
    開封第一講書人閱讀 58,737評論 1 294
  • 正文 為了忘掉前任兔朦,我火速辦了婚禮,結(jié)果婚禮上磨确,老公的妹妹穿的比我還像新娘沽甥。我一直安慰自己,他們只是感情好乏奥,可當我...
    茶點故事閱讀 67,753評論 6 392
  • 文/花漫 我一把揭開白布摆舟。 她就那樣靜靜地躺著,像睡著了一般邓了。 火紅的嫁衣襯著肌膚如雪恨诱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,598評論 1 305
  • 那天骗炉,我揣著相機與錄音照宝,去河邊找鬼。 笑死句葵,一個胖子當著我的面吹牛厕鹃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播乍丈,決...
    沈念sama閱讀 40,338評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼剂碴,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了轻专?” 一聲冷哼從身側(cè)響起忆矛,我...
    開封第一講書人閱讀 39,249評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎请垛,沒想到半個月后催训,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,696評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡宗收,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,888評論 3 336
  • 正文 我和宋清朗相戀三年瞳腌,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片镜雨。...
    茶點故事閱讀 40,013評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡嫂侍,死狀恐怖儿捧,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情挑宠,我是刑警寧澤菲盾,帶...
    沈念sama閱讀 35,731評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站各淀,受9級特大地震影響懒鉴,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜碎浇,卻給世界環(huán)境...
    茶點故事閱讀 41,348評論 3 330
  • 文/蒙蒙 一临谱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧奴璃,春花似錦悉默、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至雳旅,卻和暖如春跟磨,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背攒盈。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評論 1 270
  • 我被黑心中介騙來泰國打工抵拘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人型豁。 一個月前我還...
    沈念sama閱讀 48,203評論 3 370
  • 正文 我出身青樓仑濒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親偷遗。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,960評論 2 355

推薦閱讀更多精彩內(nèi)容

  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,456評論 0 13
  • var 1.可以重復聲明 2.無法限制修改 3.沒有塊級作用域 let不能重復聲明驼壶,變量-可以修改氏豌,塊級作用域 c...
    Allen張小源閱讀 397評論 0 1
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile麗語閱讀 3,837評論 0 6
  • 1. let和const let(變量)不會重復聲明變量-可以修改塊級作用域 const(常量)不會重復聲明常量-...
    icon6閱讀 319評論 0 0
  • 轉(zhuǎn)載:在開發(fā)中泵喘,數(shù)組的使用場景非常多,平日中也涉及到很多數(shù)組的api/相關(guān)操作般妙,一直也沒有對這塊內(nèi)容進行一塊整理總...
    七色煙火閱讀 3,219評論 0 3