91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

      手機(jī)站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

      千鋒教育

      掃一掃進(jìn)入千鋒手機(jī)站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學(xué)習(xí)站小程序
      隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

      當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 深入探究ES6 for...in

      深入探究ES6 for...in

      來(lái)源:千鋒教育
      發(fā)布人:xqq
      時(shí)間: 2023-11-24 21:21:21 1700832081

      一、基礎(chǔ)用法

      ES6中的for...in循環(huán)與ES5中的for...in有所區(qū)別。在ES5中,使用for...in循環(huán)來(lái)迭代對(duì)象的屬性,在迭代時(shí),可以遍歷對(duì)象的自有屬性和繼承屬性。在ES6中,使用for...in循環(huán)遍歷對(duì)象的屬性時(shí),只遍歷對(duì)象的自有屬性,不會(huì)遍歷繼承屬性。

      
          const obj = {a: 1, b: 2, c: 3};
          for (let key in obj) {
            console.log(key); // 'a' 'b' 'c'
            console.log(obj[key]); // 1 2 3
          }
      

      在上面的例子中,使用for...in循環(huán)遍歷了對(duì)象obj中的屬性,并打印出了屬性名和屬性值。需要注意的是,在循環(huán)中使用let聲明變量key避免了全局變量的問(wèn)題。

      二、迭代順序

      在ES6中,對(duì)象中的屬性是有序的,按照從添加到對(duì)象中的順序排序。使用for...in循環(huán)會(huì)按照這個(gè)順序迭代對(duì)象的屬性。但是需要注意的是,如果對(duì)象的key是字符串,那么它們的遍歷順序是不確定的。

      
          const obj = {a: 1, b: 2, c: 3};
          console.log(Object.getOwnPropertyNames(obj)); // ['a', 'b', 'c']
          
          const arr = ['a', 'b', 'c'];
          for (let key in arr) {
            console.log(key); // '0' '1' '2'
            console.log(arr[key]); // 'a' 'b' 'c'
          }
      

      在上面的例子中,第一個(gè)例子打印了對(duì)象的屬性名數(shù)組,按照添加的順序打印了a、b和c。第二個(gè)例子循環(huán)遍歷了一個(gè)數(shù)組,輸出了數(shù)組的下標(biāo)和對(duì)應(yīng)的元素。

      三、遍歷Map和Set

      在ES6中,Set和Map是常用的數(shù)據(jù)結(jié)構(gòu)。使用for...in循環(huán)可以迭代它們的值,其遍歷順序與插入順序相同。

      
          const set = new Set(['a', 'b', 'c']);
          for (let val of set) {
            console.log(val); // 'a' 'b' 'c'
          }
          
          const map = new Map([['a', 1], ['b', 2], ['c', 3]]);
          for (let key of map.keys()) {
            console.log(key); // 'a' 'b' 'c'
          }
          
          for (let val of map.values()) {
            console.log(val); // 1 2 3
          }
          
          for (let entry of map.entries()) {
            console.log(entry); // ['a', 1] ['b', 2] ['c', 3]
            console.log(entry[0]); // 'a' 'b' 'c'
            console.log(entry[1]); // 1 2 3
          }
      

      在上面的例子中,第一個(gè)循環(huán)遍歷了一個(gè)Set對(duì)象,輸出了Set中的元素。第二個(gè)循環(huán)遍歷了一個(gè)Map對(duì)象的key,第三個(gè)循環(huán)遍歷了一個(gè)Map對(duì)象的value,而第四個(gè)循環(huán)遍歷了一個(gè)Map對(duì)象的每一項(xiàng)entry,然后輸出了entry的key和value。

      四、使用Symbol.iterator方法

      可以在自定義對(duì)象上使用Symbol.iterator方法來(lái)使其能夠被for...of循環(huán)遍歷。

      
          const iterableObject = {
              values: [1, 2, 3],
              [Symbol.iterator]() {
                  let index = -1;
                  return {
                      next: () => ({ value: this.values[++index], done: !(index in this.values) })
                  };
              }
          };
          
          for (let val of iterableObject) {
            console.log(val); // 1 2 3
          }
      

      在上面的例子中,自定義對(duì)象iterableObject中定義了一個(gè)values數(shù)組和一個(gè)Symbol.iterator方法。在Symbol.iterator方法中返回一個(gè)包含next()方法的迭代器對(duì)象,每次調(diào)用next()函數(shù)遍歷values數(shù)組中的值。

      五、結(jié)語(yǔ)

      通過(guò)本篇文章,我們深入探究了ES6中for...in循環(huán)的使用方法和注意事項(xiàng),包括基礎(chǔ)用法、迭代順序、遍歷Set和Map以及使用Symbol.iterator方法。在實(shí)際應(yīng)用中,我們可以根據(jù)具體場(chǎng)景靈活使用for...in循環(huán),提高代碼的效率和可維護(hù)性。

      tags: fileheader
      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
      請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
      免費(fèi)領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學(xué) 138****2860 剛剛成功領(lǐng)取
      王同學(xué) 131****2015 剛剛成功領(lǐng)取
      張同學(xué) 133****4652 剛剛成功領(lǐng)取
      李同學(xué) 135****8607 剛剛成功領(lǐng)取
      楊同學(xué) 132****5667 剛剛成功領(lǐng)取
      岳同學(xué) 134****6652 剛剛成功領(lǐng)取
      梁同學(xué) 157****2950 剛剛成功領(lǐng)取
      劉同學(xué) 189****1015 剛剛成功領(lǐng)取
      張同學(xué) 155****4678 剛剛成功領(lǐng)取
      鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
      董同學(xué) 138****2867 剛剛成功領(lǐng)取
      周同學(xué) 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      深入淺出popbackstack

      popbackstack是一種在Android開(kāi)發(fā)中常用的方法,其主要用途是在后退棧中返回到指定的fragment。在這篇文章中,我們將從多個(gè)方面來(lái)詳細(xì)闡述popba...詳情>>

      2023-11-24 23:34:34
      as.factor函數(shù)的完整解讀

      一、as.factor函數(shù)as.factor()是R語(yǔ)言中面向因子的函數(shù)之一。它可以將字符、數(shù)值、邏輯型、日期等類型的數(shù)據(jù)轉(zhuǎn)換為因子變量類型,常用于數(shù)據(jù)分...詳情>>

      2023-11-24 22:44:09
      用法介紹uniapp async

      uniapp是一個(gè)非常流行的跨平臺(tái)開(kāi)發(fā)框架,它支持多端打包,包括H5、小程序、APP、快應(yīng)用等等。async是uniapp中非常重要的一個(gè)函數(shù),它支持異步操...詳情>>

      2023-11-24 22:40:33
      OpenCVFFmpeg詳細(xì)解析

      一、OpenCVFFmpeg庫(kù)OpenCVFFmpeg是包含F(xiàn)Fmpeg命令行工具的OpenCV庫(kù)擴(kuò)展,它可以用于視頻&音頻解碼、編碼以及處理。FFmpeg是一個(gè)開(kāi)放源代碼的跨...詳情>>

      2023-11-24 22:36:57
      linux修改版本號(hào),linux版本更新

      linux命令怎么將高版本的oracle數(shù)據(jù)庫(kù)dmp文件換成低版本1、不可以直接導(dǎo)入,需要修改部分內(nèi)容。 以文本形式打開(kāi)oracle導(dǎo)出的dmp文件。 如圖紅...詳情>>

      2023-11-24 22:08:53