ES6中的語法

下次新項(xiàng)目一樣要用es6的寫法┗( ▔, ▔ )┛

模板字符串

之前字符串要使用大量的""(雙引號)和 '+' 來拼接才能達(dá)到我們需要的模板漠秋,比如

let name = "Henry"
let element =" <p>我的名字叫"+ name + "很高興認(rèn)識你</p>"

在拼接的過程中經(jīng)常會出現(xiàn)哪個(gè)引號多寫笙蒙,少寫,寫得不對的情況庆锦,導(dǎo)致結(jié)果出現(xiàn)問題

使用模板字符串可以解決這繁瑣的事情,模板字符串的寫法簡易很多捅位,只需要用``(Tab鍵上方)將需要拼接的字符串包起來便可,如果里面有變量搂抒,則需要用${}將變量包起來就可以了艇搀,如下代碼

let name = "Henry"
let element =`<p>我的名字叫+ ${name} + 很高興認(rèn)識你</p>` 

也可以在里面調(diào)用方法,如下代碼

let name = "Henry"
function makeUppercase(word) {
    return word.toUpperCase();
}
let template = `<p>我的名字叫+ ${makeUppercase(name)} + 很高興認(rèn)識你`
console.log(template) //<p>我的名字叫+ HENRY + 很高興認(rèn)識你

箭頭函數(shù)

es5中我們寫函數(shù)方法需要寫上function

const doublel = function(number) {
    return number * 2;
 }

箭頭函數(shù)不需要寫function,在形參后面加上=> 箭頭

 const doublel2 = (number)=> {
     return number * 2;
}

如果箭頭函數(shù)里面只有一行代碼return的話求晶,可以將return省略掉焰雕,如果只有一個(gè)形參,形參外面的括號也可以省略掉

const doublel3 = number=> number * 2
//也可以這樣寫
const doublel4 = (number=>number*5)

但是如果有兩個(gè)形參芳杏,甚至多個(gè)形參時(shí)矩屁,就需要用()將形參都包裹起來

 const doublel5 = (number1,number2)=>number1 + number2
//或者
const doublel6 = (number1,number2)=> {
     sum = number1 + number2
     return sum
}

做個(gè)小練習(xí)

map一個(gè)數(shù)組,讓數(shù)組中的值以double形式展示
 const numbers = [1,2,3];
// es5的寫法
 const sum = numbers.map(function(number) {
     return number * 2
 })
//es6 箭頭函數(shù)
 const sum2 = numbers.map(number=>number * 2)

箭頭函數(shù)還能改變this的指向

const team = {
    members:["Henry","Elyse"],
    teamName:"es6",
    teamSummary:function() {
        return this.members.map(function(member) {
            // this不知道指向誰了
            return `${member}隸屬于${this.teamName}小組`
        })
    }
}
console.log(team.teamSummary()) //["Henry隸屬于undefined小組", "Elyse隸屬于undefined小組"]

以上代碼顯示調(diào)用team.teamSummary()打印出來的this.teamName為undefined爵赵,我們知道吝秕,在全局作用域下 this對象指向的是window對象,在對象里面空幻,this的指向是當(dāng)前該對象烁峭,但是調(diào)用了map函數(shù)以后,this就不知道該指向誰了,所以顯示undefined

針對this指向约郁,可以使用以下方式解決
tips:還有其他方式改變this的指向缩挑,這里只列舉了這幾種

  1. 提前將this保存起來
const team = {
    members:["Henry","Elyse"],
    teamName:"es6",
    teamSummary:function() {
        let self = this;
        console.log(self)
        return this.members.map(function(member) {
            return `${member}隸屬于${self.teamName}小組`
        }
    }
}

2.使用bind將this保存起來

const team = {
    members:["Henry","Elyse"],
    teamName:"es6",
    teamSummary:function() {
        let self = this;
        console.log(self)
        return this.members.map(function(member) {
            return `${member}隸屬于${this.teamName}小組`
        }.bind(this))
    }
}

3.使用箭頭函數(shù)

const team = {
    members:["Henry","Elyse"],
    teamName:"es6",
    teamSummary() {
        let self = this;
        console.log(self)
        return this.members.map((member)=> {
            // this指向team
            return `${member}隸屬于${this.teamName}小組`
        })
    }
}

增強(qiáng)對象字面量

Tips:其實(shí)只是縮減代碼的作用

//使用es5
function createBookShop(inventory) {
    return {
        inventory : inventory,
        inventoryValue:function() {
            return this.inventory.reduce((total,book)=> total + book.price,0)
        },
        priceForTitle:function(title) {
            return this.inventory.find(book=> book.title === title).price
        }
    }
}
const inventory = [
    {title:"VUe",price:10},
    {title:"Angular",price:15}
];
const bookShop = createBookShop(inventory)
console.log(bookShop.inventoryValue())
console.log(bookShop.priceForTitle("Angular"))


//增強(qiáng)對象字面量的寫法,其實(shí)就是屬性如果跟值的命名一樣的話鬓梅,可以將屬性和值合并
function createBookShop(inventory) {
    return {
        inventory,
        inventoryValue() {
            return this.inventory.reduce((total,book)=> total + book.price,0)
        },
        priceForTitle(title) {
            return this.inventory.find(book=> book.title === title).price
        }
    }
}
const inventory = [
    {title:"VUe",price:10},
    {title:"Angular",price:15}
];
const bookShop = createBookShop(inventory)
console.log(bookShop.inventoryValue())
console.log(bookShop.priceForTitle("Angular"))

函數(shù)參數(shù)默認(rèn)值

es5中供置,如果形參和實(shí)參數(shù)量不相等,要判斷是否存在某個(gè)實(shí)參傳過來绽快,需要寫判斷語句

//es5
function makeAjaxRequest(url,method) {
    if(!method) {
        method = "get"
    }
    return method
}
console.log(makeAjaxRequest("google.com"))

函數(shù)參數(shù)默認(rèn)值是指如果某個(gè)實(shí)參不存在的話士袄,就給他顯示默認(rèn)值

//es6
function makeAjaxRequest(url,method = "get") {
    return method
}
console.log(makeAjaxRequest("google.com"))

function User(id) {
    this.id = id;
}
console.log(new User(1))
function randomId() {
    return Math.random() * 999999
}
console.log(new User(randomId()))

展開運(yùn)算符

function addNumbers(...numbers) {
    return numbers.reduce((sum,number) => {
        return sum + number
    },0)
} 
 console.log(addNumbers(1,2,3,4,5,6,7,8,9))

解構(gòu)

var expense = {
     type:"es6",
     amount:"45"
 }
// 普通取值
 var type = expense.type
 var amount = expense.amount
console.log(type,amount) //es6 45
// 解構(gòu)取值
const {type,amount,abc} = expense
 console.log(type,amount,abc) //es6 45 undefined
var saveFiled = {
    extension:"jpg",
    name:"girl",
    size:14040
}
es5
function fileSammary(file) {
    return `${file.name}.${file.extension}的總大小是${file.size}`
}
 es6
function fileSammary({name,extension,size}) {
    return `${name}.${extension}的總大小是${size}`
}
console.log(fileSammary(saveFiled))

const names = ["henry","bucky","emily"] //中括號
解構(gòu)
const [name1,name2,name3] = names;
console.log(name1,name2,name3)
const {length} = names //花括號
console.log(length)

結(jié)合展開運(yùn)算符
const [name,...rest] = names
console.log(name)

const people = [
    {name:"henry",age:20},
    {name:"bucky",age:25},
    {name:"emily",age:30}
];

es5
var age = people[0].age;
console.log(age)
es6 解構(gòu)
const [{age}] = people
console.log(age)



使用場景,將數(shù)組轉(zhuǎn)化為對象
const points = [
    [4,5],
    [10,1],
    [0,40]
];

期望數(shù)據(jù)格式
[
    {x:4,y:5},
    {x:10,y:1},
    {x:0,y:40}
]
方法一
let newPoints = points.map(pair=> {
    const [x,y] = pair
    return {x,y}
})
console.log(newPoints)
方法二
let newPoints = points.map(([x,y])=> {
        return {x,y}
})
console.log(newPoints)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谎僻,一起剝皮案震驚了整個(gè)濱河市娄柳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌艘绍,老刑警劉巖赤拒,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異诱鞠,居然都是意外死亡挎挖,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進(jìn)店門航夺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蕉朵,“玉大人,你說我怎么就攤上這事阳掐∈夹疲” “怎么了?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵缭保,是天一觀的道長汛闸。 經(jīng)常有香客問我,道長艺骂,這世上最難降的妖魔是什么诸老? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮钳恕,結(jié)果婚禮上别伏,老公的妹妹穿的比我還像新娘。我一直安慰自己忧额,他們只是感情好厘肮,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著宙址,像睡著了一般轴脐。 火紅的嫁衣襯著肌膚如雪调卑。 梳的紋絲不亂的頭發(fā)上抡砂,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天大咱,我揣著相機(jī)與錄音,去河邊找鬼注益。 笑死碴巾,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的丑搔。 我是一名探鬼主播厦瓢,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼啤月!你這毒婦竟也來了煮仇?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤谎仲,失蹤者是張志新(化名)和其女友劉穎浙垫,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體郑诺,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡夹姥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了辙诞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片辙售。...
    茶點(diǎn)故事閱讀 40,505評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖飞涂,靈堂內(nèi)的尸體忽然破棺而出旦部,到底是詐尸還是另有隱情,我是刑警寧澤较店,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布志鹃,位于F島的核電站,受9級特大地震影響泽西,放射性物質(zhì)發(fā)生泄漏曹铃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一捧杉、第九天 我趴在偏房一處隱蔽的房頂上張望陕见。 院中可真熱鬧,春花似錦味抖、人聲如沸评甜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忍坷。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間佩研,已是汗流浹背柑肴。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留旬薯,地道東北人晰骑。 一個(gè)月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像绊序,于是被迫代替她去往敵國和親硕舆。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評論 2 359