ES6這些就夠了

1.變量聲明const和let

在ES6之前唯欣,我們都是用var關(guān)鍵字聲明變量居触。無論聲明在何處拜秧,都會被視為聲明在函數(shù)的最頂部(不在函數(shù)內(nèi)即在全局作用域的最頂部)痹屹。這就是函數(shù)變量提升例如:

  function aa() {
    if(flag) {
        var test = 'hello man'
    } else {
        console.log(test)
    }
  }

以上的代碼實(shí)際上是:

  function aa() {
    var test // 變量提升,函數(shù)最頂部
    if(flag) {
        test = 'hello man'
    } else {
        //此處訪問 test 值為 undefined
        console.log(test)
    }
    //此處訪問 test 值為 undefined
  }

所以不用關(guān)心flag是否為 true or false枉氮。實(shí)際上志衍,無論如何 test 都會被創(chuàng)建聲明。

接下來ES6主角登場:
我們通常用 letconst 來聲明聊替,let 表示變量楼肪、const 表示常量letconst 都是塊級作用域惹悄。怎么理解這個塊級作用域春叫?

  • 在一個函數(shù)內(nèi)部
  • 在一個代碼塊內(nèi)部

說白了只要在{}花括號內(nèi)的代碼塊即可以認(rèn)為 letconst 的作用域。

看以下代碼:

  function aa() {
    if(flag) {
       let test = 'hello man'
    } else {
        //test 在此處訪問不到
        console.log(test)
    }
  }

let 的作用域是在它所在當(dāng)前代碼塊俘侠,但不會被提升到當(dāng)前函數(shù)的最頂部。

再來說說 const
const 聲明的變量必須提供一個值蔬将,而且會被認(rèn)為是常量爷速,意思就是它的值被設(shè)置完成后就不能再修改了。

    const name = 'lux'
    name = 'joe' // 再次賦值此時會報錯

還有霞怀,如果 const 的是一個對象惫东,對象所包含的值是可以被修改的。抽象一點(diǎn)兒說毙石,就是對象所指向的地址不能改變廉沮,而變量成員是可以修改的。

    const student = { name: 'cc' }
    // 沒毛病
    student.name = 'yy'
    // 如果這樣子就會報錯了
    student  = { name: 'yy' }

說說TDZ(暫時性死區(qū))徐矩,想必你早有耳聞滞时。

    {
        console.log(value) // 報錯
        let value = 'lala'
    }

我們都知道,JS引擎掃描代碼時滤灯,如果發(fā)現(xiàn)變量聲明坪稽,用 var 聲明變量時會將聲明提升到函數(shù)或全局作用域的頂部。但是 let 或者 const鳞骤,會將聲明關(guān)進(jìn)一個小黑屋也是TDZ(暫時性死區(qū))窒百,只有執(zhí)行到變量聲明這句語句時,變量才會從小黑屋被放出來豫尽,才能安全使用這個變量篙梢。

哦了,說一道面試題

    var funcs = []
    for (var i = 0; i < 10; i++) {
        funcs.push(function() { console.log(i) })
    }
    funcs.forEach(function(func) {
        func()
    })

這樣的面試題是大家很常見美旧,很多同學(xué)一看就知道輸出十次10
但是如果我們想依次輸出0到9呢渤滞?
有兩種解決方法贬墩,直接看一下代碼:

    // ES5知識,我們可以利用“立即調(diào)用函數(shù)”解決這個問題
    var funcs = []
    for (var i = 0; i < 10; i++) {
        funcs.push(
          (function(value) {
            return function() {
                console.log(value)
            }
        })(i)
      )
    }
    funcs.forEach(function(func) {
        func()
    })

  // 再來看看es6怎么處理的
    const funcs = []
    for (let i = 0; i < 10; i++) {
        funcs.push(function() {
            console.log(i)
        })
    }
    funcs.forEach(func => func())

達(dá)到相同的效果蔼水,ES6 簡潔的解決方案是不是更讓你心動U鹛恰!趴腋!

2.字符串

先聊聊模板字符串??
ES6模板字符簡直是開發(fā)者的福音啊吊说,解決了 ES5 在字符串功能上的痛點(diǎn)。

第一個用途优炬,基本的字符串格式化颁井。將表達(dá)式嵌入字符串中進(jìn)行拼接。用${}來界定蠢护。

    //ES5 
    var name = 'lux'
    console.log('hello' + name)
    //es6
    const name = 'lux'
    console.log(`hello ${name}`) //hello lux

第二個用途雅宾,在ES5時我們通過反斜杠()來做多行字符串或者字符串一行行拼接。ES6反引號(``)直接搞定葵硕。

    // ES5
    var msg = "Hi \
    man!
    "
    // ES6
    const template = `<div>
        <span>hello world</span>
    </div>`

對于字符串 ES6+ 當(dāng)然也提供了很多厲害也很有意思的方法?? 說幾個常用的眉抬。

    // 1.includes:判斷是否包含然后直接返回布爾值
    const str = 'hahay'
    console.log(str.includes('y')) // true

    // 2.repeat: 獲取字符串重復(fù)n次
    const str = 'he'
    console.log(str.repeat(3)) // 'hehehe'
    //如果你帶入小數(shù), Math.floor(num) 來處理
    // s.repeat(3.1) 或者 s.repeat(3.9) 都當(dāng)做成 s.repeat(3) 來處理

    // 3\. startsWith 和 endsWith 判斷是否以 給定文本 開始或者結(jié)束
    const str =  'hello world!'
    console.log(str.startsWith('hello')) // true
    console.log(str.endsWith('!')) // true

    // 4\. padStart 和 padEnd 填充字符串,應(yīng)用場景:時分秒
    setInterval(() => {
        const now = new Date()
        const hours = now.getHours().toString()
        const minutes = now.getMinutes().toString()
        const seconds = now.getSeconds().toString()
        console.log(`${hours.padStart(2, 0)}:${minutes.padStart(2, 0)}:${seconds.padStart(2, 0)}`)
    }, 1000)

關(guān)于模板字符串現(xiàn)在比較常出現(xiàn)的面試題有兩道懈凹。同學(xué)們不妨寫試試看蜀变?

  • 模擬一個模板字符串的實(shí)現(xiàn)。
    let address = '北京海淀區(qū)'
    let name = 'lala'
    let str = '${name}在${address}上班...'
    // 模擬一個方法 myTemplate(str) 最終輸出 'lala在北京海淀區(qū)上班...'
    function myTemplate(str) {
        // try it
    }
    console.log(myTemplate(str)) // lala在北京海淀區(qū)上班...

  • 實(shí)現(xiàn)標(biāo)簽化模板(自定義模板規(guī)則)介评。
    const name = 'cc'
    const gender = 'male'
    const hobby = 'basketball'
    // 實(shí)現(xiàn)tag最終輸出 '姓名:**cc**库北,性別:**male**,愛好:**basketball**'
    function tag(strings) {
        // do it
    }
    const str = tag`姓名:${name}们陆,性別:${gender}寒瓦,愛好:${hobby}`
    console.log(str) // '姓名:**cc**,性別:**male**坪仇,愛好:**basketball**'

3.函數(shù)

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

在ES5我們給函數(shù)定義參數(shù)默認(rèn)值是怎么樣杂腰?

    function action(num) {
        num = num || 200
        //當(dāng)傳入num時,num為傳入的值
        //當(dāng)沒傳入?yún)?shù)時椅文,num即有了默認(rèn)值200
        return num
    }

但細(xì)心觀察的同學(xué)們肯定會發(fā)現(xiàn)颈墅,num傳入為0的時候就是false,但是我們實(shí)際的需求就是要拿到num = 0雾袱,此時num = 200 明顯與我們的實(shí)際想要的效果明顯不一樣

ES6為參數(shù)提供了默認(rèn)值恤筛。在定義函數(shù)時便初始化了這個參數(shù),以便在參數(shù)沒有被傳遞進(jìn)去時使用芹橡。

    function action(num = 200) {
        console.log(num)
    }
    action(0) // 0
    action() //200
    action(300) //300

箭頭函數(shù)

ES6很有意思的一部分就是函數(shù)的快捷寫法毒坛。也就是箭頭函數(shù)。

箭頭函數(shù)最直觀的三個特點(diǎn)。

  • 不需要 function 關(guān)鍵字來創(chuàng)建函數(shù)
  • 省略 return 關(guān)鍵字
  • 繼承當(dāng)前上下文的 this 關(guān)鍵字
//例如:
    [1,2,3].map(x => x + 1)

//等同于:
    [1,2,3].map((function(x){
        return x + 1
    }).bind(this))

說個小細(xì)節(jié)煎殷。

當(dāng)你的函數(shù)有且僅有一個參數(shù)的時候屯伞,是可以省略掉括號的。當(dāng)你函數(shù)返回有且僅有一個表達(dá)式的時候可以省略{} 和 return豪直;例如:

    var people = name => 'hello' + name
    //參數(shù)name就沒有括號

作為參考

    var people = (name, age) => {
        const fullName = 'hello' + name
        return fullName
    } 
    //如果缺少()或者{}就會報錯

要不整一道筆試題劣摇?哈哈哈哈哈哈哈哈。我不管我先上代碼了

    // 請使用ES6重構(gòu)以下代碼

    var calculate = function(x, y, z) {
      if (typeof x != 'number') { x = 0 }
      if (typeof y != 'number') { y = 6 }

      var dwt = x % y
      var result

      if (dwt == z) { result = true }
      if (dwt != z) { result = false }

      return result
    }

    const calculate = (x, y, z) => {
      x = typeof x !== 'number' ? 0 : x
      y = typeof y !== 'number' ? 6 : y
      return x % y === z
    }

4.拓展的對象功能

對象初始化簡寫

ES5我們對于對象都是以鍵值對的形式書寫弓乙,是有可能出現(xiàn)鍵值對重名的末融。例如:

    function people(name, age) {
        return {
            name: name,
            age: age
        };
    }

鍵值對重名,ES6可以簡寫如下:

    function people(name, age) {
        return {
            name,
            age
        };
    }

ES6 同樣改進(jìn)了為對象字面量方法賦值的語法暇韧。ES5為對象添加方法:

    const people = {
        name: 'lux',
        getName: function() {
            console.log(this.name)
        }
    }

ES6通過省略冒號與 function 關(guān)鍵字勾习,將這個語法變得更簡潔

    const people = {
        name: 'lux',
        getName () {
            console.log(this.name)
        }
    }

ES6 對象提供了 Object.assign()這個方法來實(shí)現(xiàn)淺復(fù)制。
Object.assign() 可以把任意多個源對象自身可枚舉的屬性拷貝給目標(biāo)對象懈玻,然后返回目標(biāo)對象巧婶。第一參數(shù)即為目標(biāo)對象。在實(shí)際項(xiàng)目中涂乌,我們?yōu)榱瞬桓淖冊磳ο笠照弧R话銜涯繕?biāo)對象傳為{}

    const objA = { name: 'cc', age: 18 }
    const objB = { address: 'beijing' }
    const objC = {} // 這個為目標(biāo)對象
    const obj = Object.assign(objC, objA, objB)

    // 我們將 objA objB objC obj 分別輸出看看
    console.log(objA)   // { name: 'cc', age: 18 }
    console.log(objB) // { address: 'beijing' }
    console.log(objC) // { name: 'cc', age: 18, address: 'beijing' }
    console.log(obj) // { name: 'cc', age: 18, address: 'beijing' }

    // 是的,目標(biāo)對象ObjC的值被改變了湾盒。
    // so湿右,如果objC也是你的一個源對象的話。請?jiān)趏bjC前面填在一個目標(biāo)對象{}
    Object.assign({}, objC, objA, objB)

5.更方便的數(shù)據(jù)訪問--解構(gòu)

數(shù)組和對象是JS中最常用也是最重要表示形式历涝。為了簡化提取信息诅需,ES6新增了解構(gòu)漾唉,這是將一個數(shù)據(jù)結(jié)構(gòu)分解為更小的部分的過程

ES5我們提取對象中的信息形式如下:

    const people = {
        name: 'lux',
        age: 20
    }
    const name = people.name
    const age = people.age
    console.log(name + ' --- ' + age)

是不是覺得很熟悉荧库,沒錯,在ES6之前我們就是這樣獲取對象信息的赵刑,一個一個獲取》稚溃現(xiàn)在,解構(gòu)能讓我們從對象或者數(shù)組里取出數(shù)據(jù)存為變量般此,例如

    //對象
    const people = {
        name: 'lux',
        age: 20
    }
    const { name, age } = people
    console.log(`${name} --- ${age}`)
    //數(shù)組
    const color = ['red', 'blue']
    const [first, second] = color
    console.log(first) //'red'
    console.log(second) //'blue'

要不來點(diǎn)兒面試題蚪战,看看自己的掌握情況?

    // 請使用 ES6 重構(gòu)一下代碼

    // 第一題
    var jsonParse = require('body-parser').jsonParse

    // 第二題
    var body = request.body
    var username = body.username
    var password = body.password

    // 1.
    import { jsonParse } from 'body-parser'
    // 2\. 
    const { body, body: { username, password } } = request

6.Spread Operator 展開運(yùn)算符

ES6中另外一個好玩的特性就是Spread Operator 也是三個點(diǎn)兒...接下來就展示一下它的用途铐懊。

組裝對象或者數(shù)組

    //數(shù)組
    const color = ['red', 'yellow']
    const colorful = [...color, 'green', 'pink']
    console.log(colorful) //[red, yellow, green, pink]

    //對象
    const alp = { fist: 'a', second: 'b'}
    const alphabets = { ...alp, third: 'c' }
    console.log(alphabets) //{ "fist": "a", "second": "b", "third": "c"
}

有時候我們想獲取數(shù)組或者對象除了前幾項(xiàng)或者除了某幾項(xiàng)的其他項(xiàng)

    //數(shù)組
    const number = [1,2,3,4,5]
    const [first, ...rest] = number
    console.log(rest) //2,3,4,5
    //對象
    const user = {
        username: 'lux',
        gender: 'female',
        age: 19,
        address: 'peking'
    }
    const { username, ...rest } = user
    console.log(rest) //{"address": "peking", "age": 19, "gender": "female"
}

對于 Object 而言邀桑,還可以用于組合成新的 Object 。(ES2017 stage-2 proposal) 當(dāng)然如果有重復(fù)的屬性名科乎,右邊覆蓋左邊

    const first = {
        a: 1,
        b: 2,
        c: 6,
    }
    const second = {
        c: 3,
        d: 4
    }
    const total = { ...first, ...second }
    console.log(total) // { a: 1, b: 2, c: 3, d: 4 }

7.import 和 export

import導(dǎo)入模塊壁畸、export導(dǎo)出模塊

//全部導(dǎo)入
import people from './example'

//有一種特殊情況,即允許你將整個模塊當(dāng)作單一對象進(jìn)行導(dǎo)入
//該模塊的所有導(dǎo)出都會作為對象的屬性存在
import * as example from "./example.js"
console.log(example.name)
console.log(example.age)
console.log(example.getName())

//導(dǎo)入部分
import {name, age} from './example'

// 導(dǎo)出默認(rèn), 有且只有一個默認(rèn)
export default App

// 部分導(dǎo)出
export class App extend Component {};

以前有人問我,導(dǎo)入的時候有沒有大括號的區(qū)別是什么捏萍。下面是我在工作中的總結(jié):

1.當(dāng)用export default people導(dǎo)出時太抓,就用 import people 導(dǎo)入(不帶大括號)

2.一個文件里,有且只能有一個export default令杈。但可以有多個export走敌。

3.當(dāng)用export name 時,就用import { name }導(dǎo)入(記得帶上大括號)

4.當(dāng)一個文件里逗噩,既有一個export default people, 又有多個export name 或者 export age時掉丽,導(dǎo)入就用 import people, { name, age } 

5.當(dāng)一個文件里出現(xiàn)n多個 export 導(dǎo)出很多模塊,導(dǎo)入時除了一個一個導(dǎo)入给赞,也可以用import * as example

8. Promise

在promise之前代碼過多的回調(diào)或者嵌套机打,可讀性差、耦合度高片迅、擴(kuò)展性低残邀。通過Promise機(jī)制,扁平化的代碼機(jī)構(gòu)柑蛇,大大提高了代碼可讀性芥挣;用同步編程的方式來編寫異步代碼,保存線性的代碼邏輯耻台,極大的降低了代碼耦合性而提高了程序的可擴(kuò)展性空免。

說白了就是用同步的方式去寫異步代碼。

發(fā)起異步請求

    fetch('/api/todos')
      .then(res => res.json())
      .then(data => ({ data }))
      .catch(err => ({ err }));

今天看到一篇關(guān)于面試題的很有意思盆耽。

    setTimeout(function() {
      console.log(1)
    }, 0);
    new Promise(function executor(resolve) {
      console.log(2);
      for( var i=0 ; i<10000 ; i++ ) {
        i == 9999 && resolve();
      }
      console.log(3);
    }).then(function() {
      console.log(4);
    });
    console.log(5);

Excuse me蹋砚?這個前端面試在搞事!

當(dāng)然以上promise的知識點(diǎn)摄杂,這個只是冰山一角坝咐。需要更多地去學(xué)習(xí)了解一下。

9.Generators

生成器( generator)是能返回一個迭代器的函數(shù)析恢。生成器函數(shù)也是一種函數(shù)墨坚,最直觀的表現(xiàn)就是比普通的function多了個星號*,在其函數(shù)體內(nèi)可以使用yield關(guān)鍵字,有意思的是函數(shù)會在每個yield后暫停映挂。

這里生活中有一個比較形象的例子泽篮。咱們到銀行辦理業(yè)務(wù)時候都得向大廳的機(jī)器取一張排隊(duì)號。你拿到你的排隊(duì)號柑船,機(jī)器并不會自動為你再出下一張票帽撑。也就是說取票機(jī)“暫停”住了鞍时,直到下一個人再次喚起才會繼續(xù)吐票亏拉。

OK。說說迭代器。當(dāng)你調(diào)用一個generator時专筷,它將返回一個迭代器對象弱贼。這個迭代器對象擁有一個叫做next的方法來幫助你重啟generator函數(shù)并得到下一個值。next方法不僅返回值磷蛹,它返回的對象具有兩個屬性:done和value吮旅。value是你獲得的值,done用來表明你的generator是否已經(jīng)停止提供值味咳。繼續(xù)用剛剛?cè)∑钡睦颖硬繌埮抨?duì)號就是這里的value,打印票的紙是否用完就這是這里的done槽驶。

    // 生成器
    function *createIterator() {
        yield 1;
        yield 2;
        yield 3;
    }

    // 生成器能像正規(guī)函數(shù)那樣被調(diào)用责嚷,但會返回一個迭代器
    let iterator = createIterator();

    console.log(iterator.next().value); // 1
    console.log(iterator.next().value); // 2
    console.log(iterator.next().value); // 3

那生成器和迭代器又有什么用處呢?

圍繞著生成器的許多興奮點(diǎn)都與異步編程直接相關(guān)掂铐。異步調(diào)用對于我們來說是很困難的事罕拂,我們的函數(shù)并不會等待異步調(diào)用完再執(zhí)行,你可能會想到用回調(diào)函數(shù)全陨,(當(dāng)然還有其他方案比如Promise比如Async/await)爆班。

生成器可以讓我們的代碼進(jìn)行等待。就不用嵌套的回調(diào)函數(shù)辱姨。使用generator可以確保當(dāng)異步調(diào)用在我們的generator函數(shù)運(yùn)行一下行代碼之前完成時暫停函數(shù)的執(zhí)行柿菩。

那么問題來了,咱們也不能手動一直調(diào)用next()方法雨涛,你需要一個能夠調(diào)用生成器并啟動迭代器的方法枢舶。就像這樣子的

    function run(taskDef) { //taskDef即一個生成器函數(shù)

        // 創(chuàng)建迭代器,讓它在別處可用
        let task = taskDef();

        // 啟動任務(wù)
        let result = task.next();

        // 遞歸使用函數(shù)來保持對 next() 的調(diào)用
        function step() {

            // 如果還有更多要做的
            if (!result.done) {
                result = task.next();
                step();
            }
        }

        // 開始處理過程
        step();

    }

生成器與迭代器最有趣替久、最令人激動的方面凉泄,或許就是可創(chuàng)建外觀清晰的異步操作代碼。你不必到處使用回調(diào)函數(shù)侣肄,而是可以建立貌似同步的代碼旧困,但實(shí)際上卻使用 yield 來等待異步操作結(jié)束醇份。

轉(zhuǎn)自: http://www.reibang.com/p/287e0bb867ae

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末稼锅,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子僚纷,更是在濱河造成了極大的恐慌矩距,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怖竭,死亡現(xiàn)場離奇詭異锥债,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進(jìn)店門哮肚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來登夫,“玉大人,你說我怎么就攤上這事允趟∧詹撸” “怎么了?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵潮剪,是天一觀的道長涣楷。 經(jīng)常有香客問我,道長抗碰,這世上最難降的妖魔是什么狮斗? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮弧蝇,結(jié)果婚禮上碳褒,老公的妹妹穿的比我還像新娘。我一直安慰自己看疗,他們只是感情好骤视,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著鹃觉,像睡著了一般专酗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上盗扇,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天祷肯,我揣著相機(jī)與錄音,去河邊找鬼疗隶。 笑死佑笋,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的斑鼻。 我是一名探鬼主播蒋纬,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼坚弱!你這毒婦竟也來了蜀备?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤荒叶,失蹤者是張志新(化名)和其女友劉穎碾阁,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體些楣,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡脂凶,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年宪睹,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚕钦。...
    茶點(diǎn)故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡亭病,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出嘶居,到底是詐尸還是另有隱情命贴,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布食听,位于F島的核電站胸蛛,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏樱报。R本人自食惡果不足惜葬项,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望迹蛤。 院中可真熱鬧民珍,春花似錦、人聲如沸盗飒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽逆趣。三九已至蝶溶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間宣渗,已是汗流浹背抖所。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留痕囱,地道東北人田轧。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像鞍恢,于是被迫代替她去往敵國和親傻粘。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評論 2 359

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

  • 剛開始用Vue或者React帮掉,很多時候我們都會把ES6+這位大兄dei加入我們的技術(shù)棧中弦悉。但是ES6+那么多那么多...
    陳嘻嘻啊閱讀 285,219評論 83 715
  • 本文為阮一峰大神的《ECMAScript 6 入門》的個人版提純! babel babel負(fù)責(zé)將JS高級語法轉(zhuǎn)義旭寿,...
    Devildi已被占用閱讀 1,988評論 0 4
  • 1.變量聲明const和let let表示變量警绩、const表示常量崇败。let和const都是塊級作用域 2.模板字符...
    LJQ21閱讀 119評論 0 0
  • [TOC] 參考阮一峰的ECMAScript 6 入門參考深入淺出ES6 let和const let和const都...
    郭子web閱讀 1,783評論 0 1
  • 文/亭主 小狗錢錢 這本書的作者是德國著名的投資家和企業(yè)家——博多·舍費(fèi)爾,是他專門寫給孩子和年輕人的一本理財書缩膝。...
    亭主閱讀 2,985評論 10 70