<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          5 種 for 循環(huán)一次徹底搞懂

          共 3872字,需瀏覽 8分鐘

           ·

          2022-04-18 19:17

          來源 | https://www.toutiao.com/article/7084114231976657408/


          for 循環(huán)在平時開發(fā)中使用頻率最高的,前后端數(shù)據(jù)交互時,常見的數(shù)據(jù)類型就是數(shù)組和對象,處理對象和數(shù)組時經(jīng)常使用到 for 遍歷,因此下班前花費幾分鐘徹底搞懂這 5 種 for 循環(huán)。它們分別為:

          • for

          • for ... in

          • for ... of

          • for await .. of

          • forEach

          • map

          一、各個 for 介紹

          1、for

          for 循環(huán)是出現(xiàn)最早,也是應用最普遍的一個遍歷,能夠滿足絕大多數(shù)的遍歷。可以遍歷 數(shù)組、對象、字符串,示例:

          // 遍歷數(shù)組var arr = [1, 2, 3]for (var i = 0; i < arr.length; i++){  console.log(arr[i]);}//遍歷對象var obj = {  job: 'web worker',  name:'前端代碼女神'}for (var i = 0,keys = Object.keys(obj); i< keys.length; i++){  console.log(obj[keys[i]])}
          //遍歷字符串let str = 'abc'for (var i = 0; i < str.length; i++){ console.log(str[i])}

          2、for ... in

          for ... in 是在 ES5 中新增的,以任意順序迭代一個對象的除Symbol以外的可枚舉屬性,包括繼承的可枚舉屬性。

          // 遍歷數(shù)組var arr = [1, 2, 3]for (var i in arr ){  console.log(i);//0 1 2  console.log(arr[i]);//1 2 3}//遍歷對象var obj = {  job: 'web worker',  name:'前端代碼女神'}for (var key in obj){  console.log(key)// job name  console.log(obj[key])// web worker  前端代碼女神}//遍歷字符串let str = 'abc'for (var i in str){  console.log(i) // 0 1 2  console.log(str[i]) // a b c}

          3、for ... of

          for ... of 語句在可迭代對象(包括 Array、Map、Set、String、TypedArray、arguments 對象等等)上創(chuàng)建一個迭代循環(huán),調(diào)用自定義迭代鉤子,并為每個不同屬性的值執(zhí)行語句。

          // 迭代 Arrayvar arr = [1, 2, 3]for (var val of arr ){  console.log(val);// 1 2 3}//迭代 Stringlet str = 'abc'for (var val of str){  console.log(val) // a b c}// 迭代 TypedArray - 一個類型化數(shù)組,描述了一個底層的二進制數(shù)據(jù)緩沖區(qū)!let iterable = new Uint8Array([0x00, 0xff]);
          for (let value of iterable) { console.log(value);//0 255}// 迭代 Map - 對象保存鍵值對,能夠記住鍵的原始插入順序let map = new Map([['a',1],['b',2]])for (let key of map) { console.log('key',key)//['a',1] ['b',2] }for (let [key,value] of map) { console.log(key) // a b console.log(value) // 1 2}// 迭代 Setlet set = new Set([1,2,3,2,1])for (let val of set) { console.log(val)// 1 2 3}

          4、for await...of

          創(chuàng)建一個循環(huán),該循環(huán)遍歷異步可迭代對象以及同步可迭代對象,包括內(nèi)置的 String、Array,類數(shù)組對象(arguments 或 nodeList),TypedArray, Map, Set 和用戶定義的異步/同步迭代器。

          它使用對象的每個不同屬性的值調(diào)用要執(zhí)行的語句來調(diào)用自定義迭代鉤子。

          類似于 await 運算符一樣,該語句只能在一個async function 內(nèi)部使用。

          async function* asyncGenerator() {  var i = 0;  while (i < 3) {    yield i++;  }}(async function () {  for await (num of asyncGenerator()) {    console.log(num);// 0 1 2  }})();

          5、forEach

          forEach 是ES5版本發(fā)布的,按升序為數(shù)組中含有效值的每一項執(zhí)行一次回調(diào)函數(shù),那些已刪除或者未初始化的項將被跳過(例如在稀疏數(shù)組上),一般認為是 普通for循環(huán) 的加強版。

          // 遍歷數(shù)組var arr = [1, 2, 3]arr.forEach((item, index) => {  console.log(index);//0 1 2  console.log(item);// 1 2 3})//遍歷對象var obj = {  job: 'web worker',  name:'前端代碼女神'}var keys = Object.keys(obj)keys.forEach((key) => {  console.log(key)// job name  console.log(obj[key])// web worker  前端代碼女神})

          6、map

          遍歷時可以返回一個新數(shù)組,新數(shù)組的結(jié)果是原數(shù)組中每個元素都調(diào)用一次提供的函數(shù)后返回的值。

          // 遍歷數(shù)組var arr = [1, 2, 3]let newArr = arr.map((item) => item * 2)console.log(newArr);//[2,4,6]

          二、多個 for 之間區(qū)別

          1、使用場景差異

          for循環(huán)是最早最原始的循環(huán)遍歷語句,for 內(nèi)部定義一個變量,按照條件進行循環(huán)遍歷,通常是數(shù)組的長度,當超過長度時就停止循環(huán),一般遍歷的都是數(shù)組或類數(shù)組。

          遍歷對象時,由于對象沒有長度,所以使用 Object.keys() 獲取對象的所有屬性,以數(shù)組形式返回。

          for / in主要是用來遍歷對象上的可枚舉屬性,包括原型對象上的屬性,按任意順序進行遍歷,遍歷對象時獲取到的是屬性的鍵值,遍歷的是數(shù)組,數(shù)組的下標當做鍵值。

          for / of用于遍歷可迭代對象的數(shù)據(jù),包括 Array、Map、Set、String、TypedArray、arguments 對象等等。

          for await...of用于遍歷異步可迭代對象,該語句只能在一個async function 內(nèi)部使用。

          f orEach 是 for 的加升級版,使用更簡單,攜帶參數(shù)更多,但本質(zhì)還是數(shù)組的循環(huán),每個元素都執(zhí)行一次回調(diào),不會改變原數(shù)組。

          map是給原數(shù)組每個元素都執(zhí)行一次回調(diào),返回一個新數(shù)組,不會改變原數(shù)組。

          2、功能差異

          forEach、map 不支持跳出循環(huán),其他不支持。

          for await ... of 能夠支持異步操作,其他的不支持。

          對于純對象的遍歷, for ... in 枚舉更方便。

          對于數(shù)組遍歷,如果不需要索引,可以直接使用 for...of 獲取值,還可支持 break 或 return ;如果還需要索引,使用 forEach 更適合,但不支持 return。

          如果是一個數(shù)組映射成另一個數(shù)組,使用 map 最合適。

          3、性能差異

          在測試環(huán)境、測試數(shù)據(jù)條件一致的情況下,性能排序為:

          for > for of > forEach > map > for in。

          for 因為沒有額外的函數(shù)調(diào)用和上下文,所以性能是最快的。

          for ... of 具有 iterator 接口的數(shù)據(jù)結(jié)構(gòu),可以使用它來迭代成員,直接讀取鍵值。

          forEach 是 for 的語法糖,還有許多的參數(shù)和上下文,因此會慢一些。

          map 因為它返回的是一個等長的全新數(shù)組,數(shù)組創(chuàng)建和賦值產(chǎn)生的性能開銷較大。

          for...in 性能最差,因為需要列舉對象的所有屬性,有轉(zhuǎn)化過程,開銷比較大。

          三、for 的使用

          在項目開發(fā)中,我們應該根據(jù)實際需求,去選擇一個合適的 for 遍歷。以下是一些使用建議:

          1. 如果需要把數(shù)據(jù)映射成另外一個數(shù)組,如變成對應布爾值,推薦使用 map ,不會修改原數(shù)組,使用語法簡單。

          2. 數(shù)組遍歷時,可以使用 for 、forEach 或 for...of。

          3. 遍歷的是純對象時,推薦使用 for ... in 。

          4. 如果是需要對迭代器遍歷,推薦使用 for ... of。

          5. 如果是在數(shù)組中篩選符合條件的數(shù)組,使用 fillter 。


          學習更多技能

          請點擊下方公眾號

          瀏覽 47
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  中文字幕偷拍 | 影音先锋亚洲无码AV | 久久久久久久久久国产 | 一区二区三区入口 | 婷婷五月视频在线观看 |