es6中比較有用的7個(gè)技巧小結(jié)
前言
ES6出來(lái)已經(jīng)有好幾年了,同時(shí)很多新特性可以被巧妙地運(yùn)用在項(xiàng)目中。我想要列下其中一些,希望它們對(duì)你有用。
如果你還知道其他一些小技巧,歡迎留言~ 很高興把它們補(bǔ)充進(jìn)來(lái)。
es6有用的7個(gè)技巧
數(shù)組去重
var arr = [1, 2, 3, 3, 4]; console.log(...new Set(arr)) >> [1, 2, 3, 4]
數(shù)組和布爾
有時(shí)我們需要過(guò)濾數(shù)組中值為 false 的值. 例如(0, undefined, null, false), 你可能不知道這樣的技巧
var myArray = [1, 0 , undefined, null, false]; myArray.filter(Boolean); > > [1] //是不是很簡(jiǎn)單, 只需要傳入一個(gè) Boolean 函數(shù)即可.
創(chuàng)建一個(gè)空對(duì)象
有時(shí)我們需要?jiǎng)?chuàng)建一個(gè)純凈的對(duì)象, 不包含什么原型鏈等等. 一般創(chuàng)建空對(duì)象最直接方式通過(guò)字面量 {}, 但這個(gè)對(duì)象中依然存在 proto 屬性來(lái)指向 Object.prototype 等等.
let dict = Object.create(null); dict.__proto__ === "undefined"
合并對(duì)象
在JavaScript中合并多個(gè)對(duì)象的需求一直存在, 比如在傳參時(shí)需要把表單參數(shù)和分頁(yè)參數(shù)進(jìn)行合并后在傳遞給后端
const page = {
current: 1,
pageSize: 10
}
const form = {
name: "",
sex: ""
}
const params = {...form, ...page};
/*
{
name: "",
sex: "",
current: 1,
pageSize: 10
}
*
利用ES6提供的擴(kuò)展運(yùn)算符讓對(duì)象合并變得很簡(jiǎn)單.
函數(shù)參數(shù)必須
ES6中可以給參數(shù)指定默認(rèn)值,確實(shí)帶來(lái)很多便利. 如果需要檢測(cè)某些參數(shù)是必傳時(shí),可以這么做
const isRequired = () => { throw new Error('param is required'); };
const hello = (name = isRequired()) => { console.log(`hello ${name}`) };
// 這里將拋出一個(gè)錯(cuò)誤,因?yàn)槊謺r(shí)必須
hello();
// 這也將拋出一個(gè)錯(cuò)誤
hello(undefined);
// 正常
hello(null);
hello('David');
解構(gòu)賦值時(shí)使用別名
解構(gòu)賦值是一個(gè)非常受歡迎的JavaScript功能,但有時(shí)我們更喜歡用其他名稱(chēng)引用這些屬性,所以我們可以利用別名來(lái)完成:
const obj = { x: 1 };
// Grabs obj.x as { x }
const { x } = obj;
// Grabs obj.x as { otherName }
const { x: otherName } = obj;
獲取查詢(xún)參數(shù)
多年來(lái),我們編寫(xiě)粗糙的正則表達(dá)式來(lái)獲取查詢(xún)字符串值,但那些日子已經(jīng)一去不復(fù)返了; 現(xiàn)在我們可以通過(guò) URLSearchParams API 來(lái)獲取查詢(xún)參數(shù)
在不使用 URLSearchParams 我們通過(guò)正則的方式來(lái)完成獲取查詢(xún)參數(shù)的, 如下:
function getQueryString(name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
return r ? r[2] : null;
}
使用 URLSearchParams 之后:
// 假設(shè)地址欄中查詢(xún)參數(shù)是這樣 "?post=1234&action=edit"
var urlParams = new URLSearchParams(window.location.search);
console.log(urlParams.has('post')); // true
console.log(urlParams.get('action')); // "edit"
console.log(urlParams.getAll('action')); // ["edit"]
console.log(urlParams.toString()); // "?post=1234&action=edit"
console.log(urlParams.append('active', '1')); // "?post=1234&action=edit&active=1"
相比之前使用起來(lái)更加容易了
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
JavaScript及jquey實(shí)現(xiàn)多個(gè)數(shù)組的合并操作
這篇文章主要介紹了JavaScript及jquey實(shí)現(xiàn)多個(gè)數(shù)組的合并操作,在某些情況下還是比較實(shí)用的,需要的朋友可以參考下2014-09-09
Bootstrap table分頁(yè)問(wèn)題匯總
這篇文章主要為大家匯總了Bootstrap table分頁(yè)的典型問(wèn)題,以及對(duì)應(yīng)每個(gè)bootstrap table分頁(yè)問(wèn)題的解決方法,感興趣的小伙伴們可以參考一下2016-05-05
微信小程序?qū)崿F(xiàn)錨點(diǎn)跳轉(zhuǎn)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)錨點(diǎn)跳轉(zhuǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)截圖功能
這篇文章主要介紹了JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)截圖功能,本文介紹了2款實(shí)現(xiàn)JavaScript截圖的開(kāi)源組件,一個(gè)是Canvas2Image,一個(gè)是html2canvas,需要的朋友可以參考下2014-10-10
JavaScript實(shí)現(xiàn)彈窗效果代碼分析
本文主要介紹了JavaScript實(shí)現(xiàn)彈窗效果的代碼分析,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03

