国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

《ES6標準入門》讀書筆記

HollisChuang / 2187人閱讀

摘要:標準入門讀書筆記和命令新增命令,用于聲明變量,是塊級作用域。用于頭部補全,用于尾部補全。函數(shù)調用的時候會在內存形成一個調用記錄,又稱為調用幀,保存調用位置和內部變量等信息。等到執(zhí)行結束再返回給,的調用幀才消失。

《ES6標準入門》讀書筆記

@(StuRep)

let和const命令

ES6新增let命令,用于聲明變量,是塊級作用域。

let聲明的變量不會像var聲明的變量發(fā)生“變量提升”現(xiàn)象,所以,變量一定要在聲明后使用,不然就會報錯。

暫時性死區(qū):只要塊級作用域內存在let命令,它所聲明的變量就會“綁定”在這個區(qū)域,不再受外部的影響。即在代碼塊內,使用let命令聲明變量之前,這個變量都是不可用的,這在語法上稱為“暫時性死區(qū)”。

ES6規(guī)定暫時性死區(qū)和不存在變量提升,主要是為了減少運行時的錯誤,防止在變量聲明前就使用這個變量,導致意外,這樣的錯誤在ES5中很常見。

let不允許在相同作用域內重復聲明同一個變量。

const命令用來聲明常量,聲明了之后就不能再改變,所以在聲明的時候就必須賦值,這個命令同樣是塊級作用域,同樣存在暫時性死區(qū)。

對于用const聲明的對象,變量名不會指向對象的數(shù)據(jù),而是指向對象所在的地址,所以用const聲明的復合類型變量中的數(shù)據(jù)是可以改變的,這點需要當心!

變量的解構賦值

解構:ES6允許按照一定模式,從數(shù)組和對象中提取值,對變量進行賦值,這被成為解構。如下:

//ES5
var a = 1;
var b = 2;
var c = 3;

//ES6
var [a, b, c] = [1, 2, 3];

//嵌套
let [foo, [[bar], baz]] = [1, [[2], 3]];
foo;//1
bar;//2
baz;//3

//如果等號右邊不是可以遍歷的結構,就無法匹配就會報錯。

解構賦值是允許設置默認值的,在ES6內部使用"==="來判斷一個位置是否有值。所以,如果一個數(shù)組成員不嚴格等于undefined,默認值是不會生效的。例如:

[x, y = "b"] = ["a", undefined];//x="a",y="b"
[x = 1] = [null];//x=null

默認值可以引用解構賦值的其他變量,但該變量必須已經(jīng)聲明。例如:

let [x = 1, y = x] = []; //x=1; y=1
let [x = 1, y = x] = [2]; //x=2; y=2
let [x = 1, y = x] = [1, 2]; //x=1; y=2
let [x = y, y = 1] = []; //報錯,因為x在使用y作為其默認值的時候y還沒有被聲明

對象的解構賦值:

var {foo, bar} = {foo: "aaa", bar:"bbb"};
foo //"aaa"
bar //"bbb"

對象的解構賦值和數(shù)組有一個重要的不同:數(shù)組的元素是按次序排列的,變量的取值由它的位置來決定;而對象的屬性沒有次序,變量必須與屬性同名,才能取到正確的值。

對象的解構賦值可以很方便地將現(xiàn)有對象的方法賦值到某個變量。例如:

let {log, sin, cos} = Math;
//這樣就可以把取對數(shù)、正弦、余弦3個方法賦值到對應的變量上面,用起來很方便;

字符串也可以解構賦值,因為字符串會被轉換成一個類似數(shù)組的對象。例如:

const [a, b, c, d, e] = "hello";
a // "h"
b // "e"
c // "l"
d // "l"
e // "o"

let {length : len} = "hello";
len //5

數(shù)值和布爾值的解構賦值:解構賦值時,如果等號右邊是數(shù)值或布爾值,則會先轉為對象。

函數(shù)參數(shù)也可以解構賦值,例如:

function add([x,y]){
    return x + y;
}

add([1, 2]) //3

變量的解構賦值的用途很多,簡潔易讀:

交換變量的值[x, y] = [y, x]

從函數(shù)返回多個值;

function example(){
    return [1, 2, 3];
}
var [a, b, c] = example();

函數(shù)參數(shù)的定義;

//有序
function f([x, y, z]){...};
f([1, 2, 3]);

//無序
function f({x, y, z}){...};
f({z:3, y:2, x:1});

提取JSON數(shù)據(jù),可以快速提取json對象中的數(shù)據(jù);

字符串的擴展
ES6加強了對Unicode的支持,并且擴展了字符串對象。

ES5對字符串對象提供了CharAt方法,返回字符串給定位置的字符。但是該方法不能識別碼點大于0xFFFF的字符。于是在ES7中提供了一個at方法,可以識別Unicode編號大于0xFFFF的字符。

includes(),startsWith(),endsWith()方法。JS中只有indexOf方法可以用來確定一個字符串是否包含在另一個字符串中,ES6又提供了三種方法:

includes():返回布爾值,表示是否找到了參數(shù)字符串;

startsWith():返回布爾值,表示參數(shù)字符串是否在源字符串的頭部;

endsWith():返回布爾值,表示參數(shù)字符串是否在源字符串的尾部;

repeat(),repeat方法返回一個新字符串,表示將原字符串重復n次。

padStart(),padEnd():ES7推出了字符串補全長度的功能。如果某個字符串長度未達指定長度,會在頭部或尾部補全。padStart用于頭部補全,padEnd用于尾部補全。如果原字符串的長度大于或等于指定的最小長度,則返回原字符串。例如:

"x".padStart(5, "ab") //"ababx"
"x".padStart(4, "ab") //"abax"

"x".padEnd(5, "ab") //"xabab"
"x".padEnd(4, "ab") //"xaba"

"xxx".padStart(2, "ab") //"xxx"

正則的擴展

在ES5中,RegExp構造函數(shù)只能接受字符串作為參數(shù)var regex = new RegExp("xyz", "i");。在ES6中允許RegExp構造函數(shù)接受正則表達式作為參數(shù),這時會返回一個原有正則表達式的拷貝。

ES6新增了使用大括號表示Unicode字符的表示法,這種表示法在正則表達式中必須加上u修飾符才能識別。例如:

/u{61}/.test("a"); //false
/u{61}/u.test("a"); //true

ES6為正則表達式新增了flags屬性,會返回正則表達式的修飾符。ES5的source屬性會返回表達式的正文。

數(shù)值的擴展

ES6提供了二進制和八進制數(shù)值的新寫法,分別用前綴0b(或0B)和0o(或0O)來表示。從ES5開始,在嚴格模式中,八進制數(shù)值就不再允許使用前綴0表示,ES6進一步明確,要使用0o前綴表示。

Number.isFinite(),Number.isNaN():ES6在Number對象上面新提供了這兩個方法,分別用于檢查Infinite(是否非無窮)和NaN這兩個特殊值。

Number.parseInt(),Number.parseFloat():ES6將全局方法parseInt()和parseFloat()移植到了Number對象上。這樣是為了逐步減少全局性的方法,使語言逐步模塊化。

//ES5
parseInt("");

//ES6
Number.parseInt("");

Number.parseInt === parseInt; //true

Number.isInteger():該方法用來判斷一個值是否為整數(shù)。

新增了一個極小的常量Number.EPSILON,當我們做計算的時候,如果誤差可以小于這個常量,那么就可以認為計算的結果是正確的。

Number.isSafeInteger():JavaScript能夠準確表示的整數(shù)范圍在-2{53}到2{53}之間,超出的就不能精確表示了,該函數(shù)用來判斷一個數(shù)是否落在這個范圍之內。

Math對象的擴展,ES6在Math對象上新增了17個與數(shù)學相關的方法:

Math.trunc():用于去除小數(shù)部分,返回整數(shù)部分;

Math.sign():用于判斷一個數(shù)到底是正數(shù)、負數(shù)還是0,整數(shù)返回1,負數(shù)返回-1,0返回0,-0返回-0,其他返回NaN;

Math.cbrt():計算一個數(shù)的立方根;

Math.clz32():返回一個數(shù)的32位無符號數(shù)有多少個前導0;

Math.imul():返回兩個數(shù)以32位帶符號整數(shù)形式相乘的結果,返回的也是一個帶符號整數(shù),例如:Math.imul(-1, 8); //-8

Math.fround():返回一個數(shù)的單精度浮點數(shù)形式;

Math.hypot():返回所有參數(shù)平方和的平方根,例如:Math.hypot(3, 4);//5

還有一些和對數(shù)運算、三角函數(shù)運算、指數(shù)運算相關的方法。

數(shù)組的擴展

Array.from():將類似數(shù)組的對象和可遍歷的對象轉為真正的數(shù)組;

Array.of():將一組數(shù)值轉換為數(shù)組,例如:Array.of(3, 11, 8) //[3,11,8]

fill()方法,使用給定值填充數(shù)組,例如:new Array(3).fill(7) //[7,7,7]

數(shù)組實例的entries()、keys()、和values()方法,主要用來遍歷數(shù)組,keys()是對鍵名的遍歷,values()是對鍵值的遍歷,entries()是對鍵值對的遍歷;

函數(shù)的擴展

ES6之前不能直接為函數(shù)的參數(shù)指定默認值,所以經(jīng)常有x = x || "XXX"這樣的寫法,ES6允許為函數(shù)的參數(shù)設置默認值,就可以這樣寫function test(x, y = "xxx"){};,這樣的設計還有一個好處就是開發(fā)人員閱讀別人的代碼一眼就能看出來在調用這個接口哪些參數(shù)是可省的。此外,這種寫法還可以和解構賦值結合使用,非常靈活。

函數(shù)的length屬性修改,如果函數(shù)中的參數(shù)有指定默認值,那么length就不會把這個參數(shù)計算進去,例如:(function(a=5){}).length;//0

作用域問題,如果一個參數(shù)的默認值是一個變量,那么這個變量所處的作用域與其他變量的作用域規(guī)則是一樣的,先是當前函數(shù)的作用域,然后才是全局作用域;

ES6引入了rest參數(shù)(形式為"...變量名"),用于獲取函數(shù)的多余參數(shù),這樣就不需要使用arguments對象了。rest參數(shù)搭配的變量是一個數(shù)組,該變量將多余的參數(shù)放入其中,例如:

function add(...values){
    let sum = 0;
    for(var val of values){
        sum += val;
    }
    return sum;
}
add(2, 5, 3); //10
//add函數(shù)是一個求和函數(shù),利用rest參數(shù)可以向該函數(shù)傳入任意數(shù)目的參數(shù)。

擴展運算符,三個點(...),作用是把一個數(shù)組轉為用逗號隔開的參數(shù)序列。例如:console.log(1,...[2,3,4],5);//1 2 3 4 5;

擴展運算符替代數(shù)組的apply方法,擴展運算符可以直接把數(shù)組拆開,例如:

//ES5
function f(x,y,z){};
var args = [0,1,2];
f.apply(null, args);

//ES6
function f(x,y,z){};
var args = [0,1,2];
f(...args);

擴展運算符提供了數(shù)組合并的新方法:

//ES5
[1,2].concat(more)
//ES6
[1,2, ...more]

擴展運算符還可以與解構賦值結合;

ES6還寫入了函數(shù)的name屬性,可以返回函數(shù)名,雖然這個屬性很早就被各個瀏覽器支持了,但是在ES6才正式寫入;

箭頭函數(shù):ES6允許使用"箭頭"(=>)定義函數(shù),例如:

var sum = (num1, num2) => num1 + num2;
//等價于
var sum = function(num1, num2){
    return num1 + num2;
}

使用箭頭函數(shù)有幾個注意點:

函數(shù)體內的this對象就是定義時所在的對象,而不是使用時所在的對象。在js中this的指向是可以改變的,但是在箭頭函數(shù)中this的指向是不變的;

不可以當作構造函數(shù)。也就是說,不可以使用new命令;

不可以使用arguments對象,該對象在函數(shù)體內不存在。如果要用,可以用ES6中的rest參數(shù)代替;

不可以使用yield命令,因此箭頭函數(shù)不能用作Generator函數(shù);

函數(shù)綁定:在ES6之后的ES7版本中有一個提案是函數(shù)綁定運算符(::),雙冒號左邊是一個對象,右邊是一個函數(shù)。這個運算符會自動將左邊的對象作為this綁定到右邊的函數(shù)上面,例如:foo::bar(...arguments)等價于bar.apply(foo,arguments;)。感覺函數(shù)綁定這個設計非常的便捷,不需要在顯式的去綁定一下上下文,期待該提案的通過(目前babel已經(jīng)支持這個寫法了);

尾調用:就是指某個函數(shù)的最后一步是調用另一個函數(shù);

尾調用優(yōu)化:尾調用之所以與其他調用不同,就在于其特殊的調用位置。函數(shù)調用的時候會在內存形成一個‘調用記錄’,又稱為‘調用幀’,保存調用位置和內部變量等信息。如果在函數(shù)A內部調用函數(shù)B,那么在A的調用幀上方還會形成一個B的調用幀。等到B執(zhí)行結束再返回給A,B的調用幀才消失。如果B的內部調用了C,那么還會產(chǎn)生一個調用幀,以此類推,所有調用幀會形成一個‘調用棧’。然而尾調用是函數(shù)的最后一步操作,所以不需要保留外層函數(shù)的調用幀,因為調用位置、內部變量等信息都不會再用到了,直接用內層函數(shù)的調用幀取代外層函數(shù)的即可;

尾遞歸:函數(shù)調用自身稱為遞歸,如果尾調用自身就稱為尾遞歸。遞歸非常耗費內存,因為需要同時保存成千上百個調用幀,很容易stackoverflow。但對于尾遞歸來說,只存在一個調用幀,所以永遠不會發(fā)生“棧溢出”錯誤。例如:

//這是一個階乘函數(shù),計算n的階乘,最多需要保存n個調用記錄,復雜度為O(n)。
function factorial(n){
    if(n === 1) return 1;
    return n * factorial(n - 1);
}
//改寫成尾遞歸,只保用一個調用記錄,則復雜度為O(1);
function factorial(n, totla){
    if(n === 1) return total;
    return factorial(n - 1, n * total);
}

由此可見‘尾調用優(yōu)化’對于遞歸操作的意義非常重大,所以一些函數(shù)式編程語言將其寫入了語言規(guī)格。ES6也是如此,第一次明確規(guī)定,所有ECMAScript的實現(xiàn),都必須部署‘尾調用優(yōu)化’。這就是說,在ES6中,只要使用尾遞歸,就不會棧溢出,節(jié)省內存。

(未完待續(xù)......)

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/79861.html

相關文章

  • 《ECMAScript 6 入門讀書筆記

    摘要:阮一峰老師開源作品。書上的示例代碼可以通過在線網(wǎng)站代碼調試工具調試。 阮一峰老師開源作品。 書上的示例代碼可以通過 在線網(wǎng)站代碼調試工具 JS Bin 調試。 作用域 作用域鏈 每個變量或函數(shù)通過執(zhí)行環(huán)境 (execution context) 定義了其有權訪問的其他數(shù)據(jù),決定了他們各自的行為; 全局執(zhí)行環(huán)境是最頂層的執(zhí)行環(huán)境,根據(jù)宿主環(huán)境的不同,表示全局執(zhí)行環(huán)境的對象也不同:在瀏覽...

    qieangel2013 評論0 收藏0
  • JS筆記

    摘要:從最開始的到封裝后的都在試圖解決異步編程過程中的問題。為了讓編程更美好,我們就需要引入來降低異步編程的復雜性。異步編程入門的全稱是前端經(jīng)典面試題從輸入到頁面加載發(fā)生了什么這是一篇開發(fā)的科普類文章,涉及到優(yōu)化等多個方面。 TypeScript 入門教程 從 JavaScript 程序員的角度總結思考,循序漸進的理解 TypeScript。 網(wǎng)絡基礎知識之 HTTP 協(xié)議 詳細介紹 HTT...

    rottengeek 評論0 收藏0
  • 《JavaScript語言精粹 修訂版》 讀書筆記

    摘要:于是我就先把這本薄的經(jīng)典書語言精粹修訂版豆瓣讀書本書簡介總共章,除去附錄,才頁,讀完并記錄了一些筆記。讀書筆記還可以分享給別人看。編程語言第版定義了的標準。程序檢查時丟棄值為函數(shù)的屬性。 之前看到這篇文章,前端網(wǎng)老姚淺談:怎么學JavaScript?,說到怎么學習JavaScript,那就是看書、分析源碼。10本書讀2遍的好處,應該大于一本書讀20遍。看書主動學習,看視頻是被動學習。看...

    EscapedDog 評論0 收藏0
  • 前端補集 - 收藏集 - 掘金

    摘要:原文地址一個非常適合入門學習的博客項目前端掘金一個非常適合入門學習的項目,代碼清晰結構合理新聞前端掘金介紹一個由編寫的新聞。深入淺出讀書筆記知乎專欄前端專欄前端掘金去年的一篇老文章,恰好今天專欄開通,遷移過來。 破解前端面試(80% 應聘者不及格系列):從閉包說起 - 掘金修訂說明:發(fā)布《80% 應聘者都不及格的 JS 面試題》之后,全網(wǎng)閱讀量超過 6W,在知乎、掘金、cnodejs ...

    YorkChen 評論0 收藏0
  • 前端補集 - 收藏集 - 掘金

    摘要:原文地址一個非常適合入門學習的博客項目前端掘金一個非常適合入門學習的項目,代碼清晰結構合理新聞前端掘金介紹一個由編寫的新聞。深入淺出讀書筆記知乎專欄前端專欄前端掘金去年的一篇老文章,恰好今天專欄開通,遷移過來。 破解前端面試(80% 應聘者不及格系列):從閉包說起 - 掘金修訂說明:發(fā)布《80% 應聘者都不及格的 JS 面試題》之后,全網(wǎng)閱讀量超過 6W,在知乎、掘金、cnodejs ...

    AbnerMing 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<