摘要:注意有些數(shù)據(jù)結(jié)構(gòu)是在現(xiàn)有數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)上計算生成的,比如的數(shù)組都部署了一下三個方法,調(diào)用后都返回遍歷器對象返回一個遍歷器對象,用于遍歷鍵名,鍵值組成的數(shù)組。
ES6是什么?
JavaScript的第六版,在ES5的基礎(chǔ)上增加了許多特性:箭頭函數(shù)、字符串插值、代理、生成器、結(jié)構(gòu)賦值、塊級作用域等等。一、let和const
ES6中明確規(guī)定,如果區(qū)塊中存在let和const命令,則這個區(qū)塊對這些命令聲明的變量從一開始就形成封閉作用域。只要在聲明之前就使用這些變量,就會報錯(暫時性死區(qū))。
作用域只局限于當(dāng)前代碼塊
使用let聲明的變量作用域不會被提升
在相同的作用域下不能聲明相同的變量
for循環(huán)體現(xiàn)let的父子作用域
const聲明一個只讀的常量
只在當(dāng)前代碼塊中有效
作用域不會被提升
不能重復(fù)聲明
聲明的常量必須賦值
二、解構(gòu)賦值let [name, age, sex] = ["李四", 20, "女"]; console.log(name); // 李四 console.log(age); // 20 console.log(sex); // 女
let { name, age, friends, pet } = { name: "張三", age: 55, friends: ["lulu", "王五"], pet: { name: "土豆", age: 5 } }; console.log(name); // 張三 console.log(age); // 55 console.log(friends); // ["lulu", "王五"] console.log(pet); // {name: "土豆", age: 5}
let { name: str } = { name: "張三" }; console.log(name); // console.log(str); // 張三
let [arr1, [arr2, arr3, [arr4, arr5]]] = [1, [2, 3, [4, 5]]]; console.log(arr1, arr2, arr3, arr4, arr5); // 1 2 3 4 5
let [arr1] = []; console.log(arr1); // undefined
let [a, , c] = [1, 2, 3]; console.log(a); // 1 console.log(c); // 3
let [a, b, c, d, e] = "我是中國人"; console.log(a); // 我 console.log(b); // 是 console.log(c); // 中 console.log(d); // 國 console.log(e); // 人三、數(shù)據(jù)集合-set
類似于數(shù)組,但是成員是唯一的,沒有重復(fù)。
let set = new Set(["張三", "李四", "王五", "張三", "李四"]); console.log(set); //{"張三", "李四", "王五"} console.log(Array.from(set)); // ["張三", "李四", "王五"]
console.log(set.size); //3
//add console.log(set.add("劉德華").add("LHH")); //{"張三", "李四", "王五", "劉德華", "LHH"} console.log(set); //{"張三", "李四", "王五", "劉德華", "LHH"} //delete console.log(set.delete("張三")); // true console.log(set.delete("李四")); // true console.log(set); //has console.log(set.has("張三")); // true console.log(set.has("張三1")); // false //clear console.log(set.clear()); // undefined console.log(set); // {}
console.log(set.keys()); // SetIterator {"張三", "李四", "王五"} console.log(set.values()); // SetIterator {"張三", "李四", "王五"}四、數(shù)據(jù)集合-map
類似于對象,也是鍵值對集合,但“鍵”的范圍不限于字符串,各種類型的值(包括對象)都可以當(dāng)作鍵.
let obj1 = { a: 1 }, obj2 = { b: 2 }; const map = new Map([ ["name", "張三"], ["age", 18], ["sex", "男"], [obj1, "今天天氣很好"], [obj2, "適合敲代碼"], [ [1, 2], "hhh" ] ]); console.log(map); console.log(map.size);
map.set("friends", ["趙六", "力氣"]).set(["dog"], "小花"); console.log(map); console.log(map.get("name")); console.log(map.get(obj1));
map.delete(obj1); console.log(map.delete("xxxx")); console.log(map);
console.log(map.has(obj1)); // true console.log(map.has(obj2)); //true
map.clear(); console.log(map); // {}
console.log(map); console.log(map.keys()); console.log(map.values()); console.log(map.entries());
map.forEach(function(value, index) { console.log(index + ":" + value); })
map.set({}, "呵呵呵呵呵"); map.set({}, "哈哈哈哈"); console.log(map); console.log({} === {});五、Symbol
let str1 = Symbol(); let str2 = Symbol(); console.log(str1 === str2); // false console.log(typeof str1); // symbol console.log(typeof str2); // symbol
let str3 = Symbol("name"); let str4 = Symbol("name"); console.log(str3); // Symbol(name) console.log(str4); // Symbol(name) console.log(str3 === str4); // false
const obj = {}; obj.name = "張三"; obj.name = "李四"; obj[Symbol("name")] = "張三"; obj[Symbol("name")] = "李四"; let a = Symbol("aa"); let b = Symbol("bb"); obj[a] = "王五" obj[b] = "kk" console.log(obj); console.log(Object.getOwnPropertySymbols(obj)); // 獲取指定對象的所有Symbol屬性名 console.log(Reflect.ownKeys(obj)); // 返回所有類型的鍵名,包括常規(guī)鍵名和Symbol鍵名
注意,Symbol函數(shù)前不能使用new命令,因?yàn)?b>Symbol是一個原始類型的值,不是對象,所以也不能添加屬性。
var s1 = Symbol.for("foo"); var s2 = Symbol.for("foo"); s1===s2; // true
上面代碼中,s1和s2都是Symbol的值,但它們都是同樣參數(shù)的Symbol.for方法生成的,所有實(shí)際上是同一個值。
Symbol.for()與Symbol()這兩種寫法都會生成新的Symbol。它們的區(qū)別是,前者會被登記在全局環(huán)境中供搜索,而后者不會。Symbol.for()不會再每次調(diào)用時都返回一個新的Symbol類型的值,而是會先檢查給定的key是否已經(jīng)存在,如果不存在才會新建一個值,比如,如果調(diào)用Symbol.for("cat")30次,每次都會返回同一個Symbol值,但是調(diào)用Symbol("cat")30次則會返回30個不同的Symbol值。
var s1 = Symbol.for("foo"); Symbol.keyFor(s1); // "foo" var s2 = Symbol("foo"); Symbol.keyFor(s2); // undefined
注:Symbol.for為Symbol值登記的名字是全局環(huán)境的,可以在不同的iframe或service worker 中取到同一個值。
iframe = document.createElement("iframe"); iframe.src = String(window.location); document.body.appendchild(iframe); iframe.contentWindow.Symbol.for("foo") === Symbol.for("foo"); // true六、class的基本運(yùn)用
function Person(name, age) { this.name = name; this.age = age; } Person.prototype = { constructor: Person, print(){ console.log("我叫" + this.name + ",今年" + this.age + "歲"); } }; //或 //Person.prototype.print = function() { // console.log("我叫" + this.name + ",今年" + this.age + "歲"); //} let person = new Person("張三", 19); console.log(person); person.print();
class Person { constructor(name, age) { this.name = name; this.age = age; } print() { console.log("我叫" + this.name + ",今年" + this.age + "歲"); } } let person = new Person("張三", 19); console.log(person); person.print();
class Animal { //構(gòu)造函數(shù) constructor(props) { this.name = props.name || "未知"; } eat() { alert(this.name + "在吃東西..."); } } //class繼承 class Bird extends Animal { //構(gòu)造函數(shù) constructor(props) { //調(diào)用實(shí)現(xiàn)父類的構(gòu)造函數(shù) super(props); this.type = props.type || "未知"; } fly() { alert(this.name + "在飛..."); } } var myBird = new Bird({ name: "鸚鵡" }) myBird.eat() // 鸚鵡在吃東西... myBird.fly() // 鸚鵡在飛...七、內(nèi)置對象擴(kuò)展
let str = "適合敲代碼!"; let className = "test"; let html = `今天的天氣很好!
${str}`; console.log(html);
Array.from
// 在body中寫了幾個li節(jié)點(diǎn) let allLis = document.querySelectorAll("li"); console.log(allLis); // NodeList(6) [li, li, li, li, li, li] console.log(Array.isArray(allLis)); // false console.log(Array.from(allLis)); // [li, li, li, li, li, li] console.log(Array.isArray(Array.from(allLis))); // true
Array.of
console.log(Array.of(1, 2, 3, 4)); // [1, 2, 3, 4] console.log(Array.of("張三", "李四", "王五")); // ["張三", "李四", "王五"]
key 和 value是一樣的,寫一個就夠了
let name = "張三"; let age = 18; let person = { name, age }; console.log(person); // {name: "張三", age: 18}
Object.assign()
let obj1 = { name: "張三" }; let obj2 = { age: 18 }; let obj3 = { sex: "男" }; let obj4 = { friends: "李四" }; let obj = {}; Object.assign(obj, obj1, obj2, obj3, obj4); console.log(Object.assign(obj, obj1, obj2, obj3, obj4)); // {name: "張三", age: 18, sex: "男", friends: "李四"} console.log(obj); // {name: "張三", age: 18, sex: "男", friends: "李四"}
延展操作符
let str = "今天的天氣很好!"; let strArr = [...str]; console.log(strArr); // ["今", "天", "的", "天", "氣", "很", "好", "!"]
let student = { name: "張三", age: 18, sex: "男" } < Person {...student}/>
let myArr = [1, 2, 10, "張三", 20, 2, 1]; console.log(new Set(myArr)); // {1, 2, 10, "張三", 20} console.log([...new Set(myArr)]); // [1, 2, 10, "張三", 20]八、函數(shù)的擴(kuò)展
function sum(num1 = 20, num2 = 10) { console.log(num1 + num2); } /* function sum(num1, num2) { num1 = num1 || 10; num2 = num2 || 10; console.log(num1 + num2); } */ sum(10, 30); // 40 sum(); // 30
function sum(name, sex, ...nums) { let result = 0; console.log(name); console.log(sex); for (let value of nums) { result += value; } return result; } /* function sum() { let result = 0; for(let value of arguments){ result += value; } return result; } */ console.log(sum("張男", "男", 10, 20, 30, 50)); // 張男 // 男 // 110
let sum = (num1, num2)=>{ return num1 + num2;}; console.log(sum(100, 300)); // 400
let nameArr = ["張三", "李四", "王五"]; nameArr.forEach((value, index) => { console.log(index + ":" + value); }); // 0:張三 // 1:李四 // 2:王五
this的指向不同
function demo() { setTimeout(function() { console.log(this); }, 500); setTimeout(() => { console.log(this); }, 1000); } let obj = { a: 1 }; demo.call(obj); // Window // {a: 1}
箭頭函數(shù)的幾個注意事項(xiàng):
函數(shù)體內(nèi)的this對象就是定義時所在的對象,而不是使用時所在的對象;
不可以當(dāng)作構(gòu)造函數(shù)。也就是不可以使用new命令,否則報錯;
不可以使用arguments對象,該對象在函數(shù)體內(nèi)不存在;可以rest參數(shù)代替(...參數(shù));
不可以使用yield命令,因此箭頭函數(shù)不能用作Generator函數(shù);
九、Iterator遍歷器和for..of循環(huán)Iterator作用:一是為各種數(shù)據(jù)結(jié)構(gòu)提供統(tǒng)一的、簡便的訪問接口;二是使得數(shù)據(jù)結(jié)構(gòu)的成員能夠按某種次序排列;三是ES6創(chuàng)建了一種新的遍歷命令——for...of循環(huán),Iterator接口主要供for...of消費(fèi)
模擬next方法返回值得例子:
var it = makeIterator(["a", "b"]); console.log(it.next()); // {value: "a", done: false} console.log(it.next()); // {value: "b", done: false} console.log(it.next()); // {value: undefined, done: true} function makeIterator(array) { var nextIndex = 0; return { next: function() { return nextIndex < array.length ? { value: array[nextIndex++], done: false } : { value: undefined, done: true } } } }
Array Map Set String TypedArray 函數(shù)的arguments對象 NodeList對象
下面例子是數(shù)組的Symbol.iterator屬性:
let arr = ["a", "b", "c"]; let iter = arr[Symbol.iterator](); console.log(iter.next()); // {value: "a", done: false} console.log(iter.next()); // {value: "b", done: false} console.log(iter.next()); // {value: "c", done: false} console.log(iter.next()); // {value: undefined, done: true}
注意:對象(Object)之所以沒有默認(rèn)部署Iterator接口,是因?yàn)閷ο髮傩缘谋闅v先后順序是不確定的。
一個數(shù)據(jù)結(jié)構(gòu)只要部署了Symbol.iterator屬性,就被視為具有Iterator接口,就可以用for...of循環(huán)它的成員。
注意:有些數(shù)據(jù)結(jié)構(gòu)是在現(xiàn)有數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)上計算生成的,比如ES6的數(shù)組、Set、Map都部署了一下三個方法,調(diào)用后都返回遍歷器對象
entries()返回一個遍歷器對象,用于遍歷[鍵名,鍵值]組成的數(shù)組。對于數(shù)組,鍵名就是索引值;對于Set,鍵名與鍵值相同。Map結(jié)構(gòu)的Iterator接口默認(rèn)就是調(diào)用entries方法
keys()返回一個遍歷器對象,用于遍歷所有的鍵名
values()返回一個遍歷器對象,用于遍歷所有的鍵值
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/101209.html
摘要:更新了個版本,最新正式版是語言的下一代標(biāo)準(zhǔn),早已在年月正式發(fā)布。基本不支持移動端瀏覽器對的支持情況版起便可以支持的新特性。比較通用的工具方案有,,,等。 1、ECMAScript是什么? 和 JavaScript 有著怎樣的關(guān)系? 1996 年 11 月,Netscape 創(chuàng)造了javascript并將其提交給了標(biāo)準(zhǔn)化組織 ECMA,次年,ECMA 發(fā)布 262 號標(biāo)準(zhǔn)文件(ECMA-...
摘要:的語法已經(jīng)出了很長的時間了,在使用上也可以通過這類的編譯工具轉(zhuǎn)譯為瀏覽器可以識別的的語法,但是依舊有很多開發(fā)在寫代碼的時候,依舊沒有用的語法,而是習(xí)慣使用老的語法,這篇文章主要會介紹解構(gòu)賦值基本用法以及在實(shí)際使用場景中相比語法的優(yōu)勢,讓大家 es6的語法已經(jīng)出了很長的時間了,在使用上也可以通過babel這類的編譯工具轉(zhuǎn)譯為瀏覽器可以識別的es5的語法,但是依舊有很多開發(fā)在寫代碼的時候,...
摘要:全局安裝本地安裝轉(zhuǎn)碼規(guī)則安裝完成后,我們可以看一下我們的文件,已經(jīng)多了選項(xiàng)。直接在線編譯提供一個在線編譯器,可以在線將代碼轉(zhuǎn)為代碼。 古語有云:君子生非異也,善假于物;工欲善其事,必先利其器。 由于有些低版本的瀏覽器還是不支持ES6語法,學(xué)習(xí)ES6,首先要學(xué)會搭建一個基本的ES6開發(fā)環(huán)境,利用工具,把ES6的語法轉(zhuǎn)變成ES5的語法。 1、使用Babel把ES6編譯成ES5 1...
摘要:但是在中,可以通過關(guān)鍵字來實(shí)現(xiàn)類的繼承的使用可以使得繼承意義更加明確并且值得一提的是,如果你使用來定義的組件,那么可以在類的構(gòu)造器里面,用簡單的的聲明方式來替代方法。 原文:The 10 min ES6 course for the beginner React Developer譯者:Jim Xiao 著名的80/20定律可以用來解釋React和ES6的關(guān)系。因?yàn)镋S6增加了超過75...
摘要:其實(shí)的面向?qū)ο蠛芏嘣砗蜋C(jī)制還是的,只不過把語法改成類似和老牌后端語言中的面向?qū)ο笳Z法一用封裝一個基本的類是不是很向和中的類其實(shí)本質(zhì)還是原型鏈,我們往下看就知道了首先說下語法規(guī)則中的就是類名,可以自定義就是構(gòu)造函數(shù),這個是關(guān)鍵字,當(dāng)實(shí)例化對 其實(shí)es6的面向?qū)ο蠛芏嘣砗蜋C(jī)制還是ES5的,只不過把語法改成類似php和java老牌后端語言中的面向?qū)ο笳Z法. 一、用es6封裝一個基本的類 ...
摘要:本質(zhì)就是一個編譯器,通過將源代碼解析成抽象語法樹將源代碼的結(jié)果一系列轉(zhuǎn)換生成目標(biāo)代碼的將目標(biāo)代碼的轉(zhuǎn)換成代碼。項(xiàng)目構(gòu)建三開發(fā)環(huán)境本地服務(wù)器搭建源碼下載地址參考資料入門阮一峰中文文檔中文網(wǎng) 注:以下教程均在 windows 環(huán)境實(shí)現(xiàn),使用其他操作系統(tǒng)的同學(xué)實(shí)踐過程可能會有些出入。 ??在上一章 webpack 項(xiàng)目構(gòu)建:(一)基本架構(gòu)搭建 我們搭建了一個最基本的 webpack 項(xiàng)目,現(xiàn)...
閱讀 658·2021-11-24 09:39
閱讀 3031·2021-11-23 10:06
閱讀 990·2021-10-08 10:05
閱讀 766·2019-08-30 10:49
閱讀 1739·2019-08-29 14:08
閱讀 1332·2019-08-29 12:48
閱讀 3329·2019-08-26 14:04
閱讀 3623·2019-08-26 13:50