国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

es6中比較有用的7個技巧小結

2024-05-06 16:53:19
字體:
來源:轉載
供稿:網友

前言

ES6出來已經有好幾年了,同時很多新特性可以被巧妙地運用在項目中。我想要列下其中一些,希望它們對你有用。

如果你還知道其他一些小技巧,歡迎留言~ 很高興把它們補充進來。

es6有用的7個技巧

數組去重

var arr = [1, 2, 3, 3, 4];console.log(...new Set(arr))>> [1, 2, 3, 4]

數組和布爾

有時我們需要過濾數組中值為 false 的值. 例如(0, undefined, null, false), 你可能不知道這樣的技巧

var myArray = [1, 0 , undefined, null, false];myArray.filter(Boolean);> > [1]//是不是很簡單, 只需要傳入一個 Boolean 函數即可.

創建一個空對象

有時我們需要創建一個純凈的對象, 不包含什么原型鏈等等. 一般創建空對象最直接方式通過字面量 {}, 但這個對象中依然存在 proto 屬性來指向 Object.prototype 等等.

let dict = Object.create(null); dict.__proto__ === "undefined" 

合并對象

在JavaScript中合并多個對象的需求一直存在, 比如在傳參時需要把表單參數和分頁參數進行合并后在傳遞給后端

const page = { current: 1, pageSize: 10} const form = { name: "", sex: ""} const params = {...form, ...page}; /* {  name: "",  sex: "",  current: 1,  pageSize: 10 }*

利用ES6提供的擴展運算符讓對象合并變得很簡單.

函數參數必須

ES6中可以給參數指定默認值,確實帶來很多便利. 如果需要檢測某些參數是必傳時,可以這么做

const isRequired = () => { throw new Error('param is required'); }; const hello = (name = isRequired()) => { console.log(`hello ${name}`) }; // 這里將拋出一個錯誤,因為名字時必須hello();// 這也將拋出一個錯誤hello(undefined); // 正常hello(null);hello('David'); 

解構賦值時使用別名

解構賦值是一個非常受歡迎的JavaScript功能,但有時我們更喜歡用其他名稱引用這些屬性,所以我們可以利用別名來完成:

const obj = { x: 1 }; // Grabs obj.x as { x }const { x } = obj; // Grabs obj.x as { otherName }const { x: otherName } = obj;

獲取查詢參數

多年來,我們編寫粗糙的正則表達式來獲取查詢字符串值,但那些日子已經一去不復返了; 現在我們可以通過 URLSearchParams API 來獲取查詢參數

在不使用 URLSearchParams 我們通過正則的方式來完成獲取查詢參數的, 如下:

 function getQueryString(name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); var r = window.location.search.substr(1).match(reg); return r ? r[2] : null; }

使用 URLSearchParams 之后:

// 假設地址欄中查詢參數是這樣 "?post=1234&action=edit" var urlParams = new URLSearchParams(window.location.search); console.log(urlParams.has('post')); // trueconsole.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"

相比之前使用起來更加容易了

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 堆龙德庆县| 香格里拉县| 密山市| 古田县| 盐池县| 南涧| 马山县| 六安市| 阳高县| 绿春县| 大同市| 施甸县| 赣州市| 隆回县| 咸阳市| 秦安县| 三江| 张家港市| 扶余县| 灌云县| 两当县| 乐至县| 南平市| 昌黎县| 昌乐县| 阿坝| 乃东县| 晋中市| 上高县| 三河市| 封开县| 南华县| 安新县| 栾川县| 渭源县| 衡阳市| 呼和浩特市| 宁南县| 沾益县| 太原市| 宝鸡市|