摘要:概述展開符號真的是一個非常好用的東西,我常用于字符串分割數(shù)組合并數(shù)組拷貝對象合并對象拷貝。
0x000 概述
展開符號真的是一個非常好用的東西,我常用于字符串分割、數(shù)組合并、數(shù)組拷貝、對象合并、對象拷貝。
0x001 語法...iterableObj0x002 函數(shù)調(diào)用的時候參數(shù)展開
這是在函數(shù)調(diào)用的時候,將參數(shù)展開,和剩余參數(shù)有區(qū)別,剩余參數(shù)是在函數(shù)聲明中使用
myFunction(...iterableObj);
案例
function add(a, b){ return a + b } add(...[1,2]) // 相當于 add(1,2) -> 30x003 數(shù)組聲明展開
可用于數(shù)組合并
[...[1,2,3],4] // 相當于[1,2,3].push(4) -> [1,2,3,4] [..."1234"] // 相當于 "1234".split("")0x004 對象展開
可用于對象合并、對象拷貝
{...{name:1},age:2} // 相當于 Objeact.assign({},{name:1},{age:2}) -> {name:1,age:2} {...{name:1}} // 相當于 Object.assign({},{name:1}) -> {name:1}0x005 babel 翻譯
字符串/數(shù)組展開
源碼
[..."1234"]
翻譯后
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } [].concat(_toConsumableArray("1234"));
對象展開
源碼
let a={...{name:1}}
翻譯后
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var a = _extends({ name: 1 });
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/99170.html
摘要:概述是一個迭代可迭代對象的方式,可迭代對象包括對象等等語法迭代數(shù)組迭代字符串迭代迭代迭代迭代集合總結(jié)只能迭代可迭代對象 0x000 概述 for...of是一個迭代可迭代對象的方式,可迭代對象包括Array、Map、Set、String、TypedArray、arguments 對象等等 0x001 語法 for(variable of iterable){ // statem...
摘要:概述也是一個新的數(shù)據(jù)結(jié)構(gòu),在中其實也經(jīng)常用到,比如下面的栗子,我們經(jīng)常這么使用一個對象,與其說他是對象,其實他更像一個,但是比起真正的,這個還是有點弱了,初始化初始化一個有一個可選的參數(shù),該參數(shù)必須是一個可迭代對象,可迭代對象包括和用戶定 0x000 概述 Map也是一個新的數(shù)據(jù)結(jié)構(gòu),在js中其實也經(jīng)常用到,比如下面的栗子,我們經(jīng)常這么使用一個對象,與其說他是對象,其實他更像一個Map...
摘要:概述反射說起來和上一章節(jié)的代理基本一樣,只是使用的方式不同,設(shè)計理念也不同。 0x000 概述 反射說起來和上一章節(jié)的代理基本一樣,只是使用的方式不同,設(shè)計理念也不同。 反射提供了一系列的靜態(tài)函數(shù),可以使用Reflect.function_name(...prams)調(diào)用,這一系列的方法和代理的處理器對象方法一致 0x001 apply 語法 Reflect.apply(targ...
摘要:概述模板字符串出來以后,單引號雙引號哪個好的爭論可以退出歷史舞臺的,模板字符串的最好語法單行文本多行文本內(nèi)嵌表達式標簽語法不太喜歡單行文本完全不單引號和雙引號,當然,轉(zhuǎn)義是不可避免的,有所得必有所失去嘛多行文本,也不用關(guān)系換行的編碼轉(zhuǎn)化問題 0x000 概述 模板字符串出來以后,單引號、雙引號哪個好的爭論可以退出歷史舞臺的,模板字符串的`最好! 0x001 語法 單行文本 `str...
摘要:概述是一個新的數(shù)據(jù)結(jié)構(gòu),和其他語言的特性差不多,當然,作為中的,他還是有一些屬于的特點。 0x000 概述 Set是一個新的數(shù)據(jù)結(jié)構(gòu),和其他語言的特性差不多,當然,作為js中的Set,他還是有一些屬于js的特點。 0x001 初始化 new Set([iterable]); 初始化一個Set有一個可選的參數(shù),這個參數(shù)必須是一個可迭代的對象,可迭代對象包括String、Array、Arr...
閱讀 1220·2023-04-25 20:31
閱讀 3730·2021-10-14 09:42
閱讀 1502·2021-09-22 16:06
閱讀 2684·2021-09-10 10:50
閱讀 3536·2021-09-07 10:19
閱讀 1782·2019-08-30 15:53
閱讀 1180·2019-08-29 15:13
閱讀 2826·2019-08-29 13:20