這次帶給大家ES6使用注意事項有哪些,以下就是實戰案例,一起來看一下。
ES6出來已經有好幾年了,同時許多新特性可以被巧妙地運用在專案中。我想要列下其中一些,希望它們對你有用。
如果你還知道其他一些小技巧,歡迎留言。我很高興把它們補充進來。
1. 強制要求參數
ES6提供了預設參數值機制,讓你為參數設定預設值,防止在函數被調用時沒有傳入這些參數。
在下面的範例中,我們寫了一個required()函數作為參數a和b的預設值。這表示如果a或b其中有一個參數沒有在呼叫時傳值,會預設required()函數,然後拋出錯誤。
const required = () => {throw new Error('Missing parameter')}; const add = (a = required(), b = required()) => a + b; add(1, 2) //3 add(1) // Error: Missing parameter.
2. 強大的reduce
陣列的reduce方法用途很廣。它一般被用來把數組中每一項規約到單一值。但是你可以利用它做更多的事。
2.1 使用reduce同時實作map和filter
假設現在有一個數列,你希望更新它的每一項(map的功能)然後篩選出一部分( filter的功能)。如果是先使用map然後filter的話,你需要遍歷這個陣列兩次。
在下面的程式碼中,我們將數列中的值加倍,然後挑選出那些大於50的數。有註意到我們是如何非常有效率地使用reduce來同時完成map和filter方法的嗎?
const numbers = [10, 20, 30, 40]; const doubledOver50 = numbers.reduce((finalList, num) => { num = num * 2; if (num > 50) { finalList.push(num); } return finalList; }, []); doubledOver50; // [60, 80]
2.2 使用reduce取代map和filter
#如果你認真閱讀了上面的程式碼,你應該能理解reduce是可以取代map和filter的。
2.3 使用reduce匹配圓括號
reduce的另一個用途是能夠匹配給定字串中的圓括號。對於一個含有圓括號的字串,我們需要知道(和)的數量是否一致,並且(是否出現在)之前。
下面的程式碼中我們使用reduce可以輕鬆地解決這個問題。我們只需要先宣告一個counter變量,初值為0。在遇到(時counter加一,遇到)時counter減一。如果左右括號數目匹配,則最終結果為0。
//Returns 0 if balanced. const isParensBalanced = (str) => { return str.split('').reduce((counter, char) => { if(counter <p style="text-align: left;"><strong>2.4 統計數組中相同項目的個數</strong></p><p style="text-align: left;">很多時候,你希望統計數組中重複出現項目的個數然後用一個物件表示。那你可以使用reduce方法處理這個陣列。 </p><p style="text-align: left;">下面的程式碼將統計每種車的數目然後把總數用一個物件表示。 </p><pre class="brush:php;toolbar:false">var cars = ['BMW','Benz', 'Benz', 'Tesla', 'BMW', 'Toyota']; var carsObj = cars.reduce(function (obj, name) { obj[name] = obj[name] ? ++obj[name] : 1; return obj; }, {}); carsObj; // => { BMW: 2, Benz: 2, Tesla: 1, Toyota: 1 }
reduce的其他用途實在太多了,我建議你閱讀MDN的相關程式碼範例。
3. 物件解構
#3.1 刪除不需要的屬性
有時候你不希望保留某些物件屬性,也許是因為它們包含敏感資訊或只是太大了(just too big)。你可能會列舉整個物件然後刪除它們,但實際上只需要簡單的將這些無用屬性賦值給變量,然後把想要保留的有用部分作為剩餘參數就可以了。
下面的程式碼裡,我們希望刪除_internal和tooBig參數。我們可以把它們賦值給internal和tooBig變量,然後在cleanObject中儲存剩下的屬性以備後用。
let {_internal, tooBig, ...cleanObject} = {el1: '1', _internal:"secret", tooBig:{}, el2: '2', el3: '3'}; console.log(cleanObject); // {el1: '1', el2: '2', el3: '3'}
3.2 在函數參數中解構嵌套物件
#在下面的程式碼中,engine是物件car中嵌套的一個物件。如果我們對engine的vin屬性感興趣,使用解構賦值可以輕鬆地得到它。
var car = { model: 'bmw 2018', engine: { v6: true, turbo: true, vin: 12345 } } const modelAndVIN = ({model, engine: {vin}}) => { console.log(`model: ${model} vin: ${vin}`); } modelAndVIN(car); // => model: bmw 2018 vin: 12345
3.3 合併物件
ES6帶來了擴充運算子(...)。它一般被用來解構數組,但你也可以用它來處理物件。
接下來,我們使用擴充運算子來展開一個新的對象,第二個物件中的屬性值會改寫第一個物件的屬性值。例如object2的b和c就會改寫object1的同名屬性。
let object1 = { a:1, b:2,c:3 } let object2 = { b:30, c:40, d:50} let merged = {…object1, …object2} //spread and re-add into merged console.log(merged) // {a:1, b:30, c:40, d:50}
4. Sets
#4.1 使用Set實作陣列去重
在ES6中,因為Set只儲存唯一值,所以你可以使用Set刪除重複。
let arr = [1, 1, 2, 2, 3, 3]; let deduped = [...new Set(arr)] // [1, 2, 3]
4.2 對Set使用陣列方法
使用扩展运算符就可以简单的将Set转换为数组。所以你可以对Set使用Array的所有原生方法。
比如我们想要对下面的Set进行filter操作,获取大于3的项。
let mySet = new Set([1,2, 3, 4, 5]); var filtered = [...mySet].filter((x) => x > 3) // [4, 5]
5. 数组解构
有时候你会将函数返回的多个值放在一个数组里。我们可以使用数组解构来获取其中每一个值。
5.1 数值交换
let param1 = 1; let param2 = 2; //swap and assign param1 & param2 each others values [param1, param2] = [param2, param1]; console.log(param1) // 2 console.log(param2) // 1
5.2 接收函数返回的多个结果
在下面的代码中,我们从/post中获取一个帖子,然后在/comments中获取相关评论。由于我们使用的是async/await,函数把返回值放在一个数组中。而我们使用数组解构后就可以把返回值直接赋给相应的变量。
async function getFullPost(){ return await Promise.all([ fetch('/post'), fetch('/comments') ]); } const [post, comments] = getFullPost();
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上是ES6使用注意事項有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在es6中,可以利用“Array.isArray()”方法判断对象是否为数组,若判断的对象是数组,返回的结果是true,若判断对象不是数组,返回的结果是false,语法为“Array.isArray(需要检测的js对象)”。

es6中遍历跟迭代的区别是:遍历强调的是要把整个数据依次全部取出来,是访问数据结构的所有元素;而迭代虽然也是依次取出数据,但是并不保证取多少,也不保证把所有的数据取完,是遍历的一种形式。

在es6中,可用Object对象的is()方法来判断两个对象是否相等,该方法检测两个变量的值是否为同一个值,判断两个对象的引用地址是否一致,语法“Object.is(对象1,对象2)”;该方法会返回布尔值,若返回true则表示两个对象相等。

转换方法:1、利用“+”给数字拼接一个空字符,语法“数字+""”;2、使用String(),可把对象的值转换为字符串,语法“String(数字对象)”;3、用toString(),可返回数字的字符串表示,语法“数字.toString()”。

在es6中,assign用于对象的合并,可以将源对象的所有可枚举属性复制到目标对象;若目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性,语法为“Object.assign(...)”

改变方法:1、利用splice()方法修改,该方法可以直接修改原数组的内容,语法为“数组.splice(开始位置,修改个数,修改后的值)”;2、利用下标访问数组元素,并重新赋值来修改数组数据,语法为“数组[下标值]=修改后的值;”。

sort排序是es6中的;sort排序是es6中用于对数组的元素进行排序的方法,该方法默认不传参,按照字符编码顺序进行排序,排序顺序可以是字母或数字,并按升序或降序,语法为“array.sort(callback(a,b))”。

在es6中,import as用于将若干export导出的内容组合成一个对象返回;ES6的模块化分为导出与导入两个模块,该方法能够将所有的导出内容包裹到指定对象中,语法为“import * as 对象 from ...”。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境