不要用for in語句對數組進行遍歷

来源:http://www.cnblogs.com/jkj-jim/archive/2017/02/11/6389572.html
-Advertisement-
Play Games

for...in主要用於對數組和對象的屬性進行遍歷。for ... in 迴圈中的代碼每執行一次,就會對數組的元素或者對象的屬性進行一次操作。 語法:for (variable in object) {...} 對數組操作 可以發現在for in函數中變數以字元串的形式出現,這時候在函數中操作a[x ...


for...in主要用於對數組和對象的屬性進行遍歷。for ... in 迴圈中的代碼每執行一次,就會對數組的元素或者對象的屬性進行一次操作。

語法for (variable in object) {...}

variable:每次迭代,一個不同的屬性名將會賦予variable。
object:可枚舉屬性被迭代的對象。

對數組操作

        var a=[5,4,3,2,1];
        var x=0;
        console.log(typeof x);//number
        for (x in a) {
            console.log("a["+x+"]: "+a[x]);
            console.log(typeof x);//string
        }
        console.log(x);//4
        console.log(typeof x);//string
//output:
//        a[0]: 5
//        a[1]: 4
//        a[2]: 3
//        a[3]: 2
//        a[4]: 1

可以發現在for in函數中變數以字元串的形式出現,這時候在函數中操作a[x+1]的話是無效的,x+1會進行字元串拼接。

對象操作

var obj={"1":"first",
   "two":"zoo",
  "3":"2",
  "three":"34",
  "4":"1",
  "2":"second"
};
for (var i in obj) { 
    console.log(i+":"+obj[i]);
};
//output:
//1:first
//2:second
//3:2
//4:1
//two:zoo
//three:34

可發現,for...in 並不能夠保證返回的是按一定順序的索引,但是它會返回所有可枚舉屬性,包括繼承屬性。

給原型添加屬性之後,預設情況下枚舉,會把原型屬性一併輸出,如下所示。由於它總是會訪問該對象的原型,看下原型上是否有屬性,這在無意中就給遍歷增加了額外的壓力。

例:

function fun4(){
var a=[1,2,3,4,5];
Array.prototype.age=13;
for(var i in a){
console.log("a["+i+"]: "+a[i]);
}
}
//outuput:
//a[0]: 1
//a[1]: 2
//a[2]: 3
//a[3]: 4
//a[4]: 5
//a[age]: 13

解決方法:

如果你只要考慮對象本身的屬性,而不是它的原型,那麼使用 getOwnPropertyNames() 或執行  hasOwnProperty() 來確定某屬性是否是對象本身的屬性 (也能使用propertyIsEnumerable)。

下麵利用 hasOwnProperty() 的方法使隱藏的繼承屬性不會被顯示。如果該對象是從原型鏈中繼承了該屬性,或者根本沒有這樣的一個屬性,則返回false。如果某個對象具有給定名稱的屬性,則返回true。

function fun4(){
var a=[1,2,3,4,5];
Array.prototype.age=13;
for(var i in a){
  if( a.hasOwnProperty( i ) ) {
    console.log("a["+i+"]: "+a[i]);
  }
}
}
//outuput:
//a[0]: 1
//a[1]: 2
//a[2]: 3
//a[3]: 4
//a[4]: 5

在迭代進行時被添加到對象的屬性,可能在之後的迭代被訪問,也可能被忽略。通常,在迭代過程中最好不要在對象上進行添加、修改或者刪除屬性的操作,除非是對當前正在被訪問的屬性。這裡並不保證是否一個被添加的屬性在迭代過程中會被訪問到,不保證一個修改後的屬性(除非是正在被訪問的)會在修改前或者修改後被訪問,不保證一個被刪除的屬性將會在它被刪除之前被訪問。

Note: 意思就是儘量不要對數組對象使用for in遍歷。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文:intro-to-vue-3-vue-cli-lifecycle-hooks 譯者:nzbin 這是 JavaScript 框架 Vue.js 五篇教程的第三部分。在這一部分,我們將學習 Vue-cli ,還會涉及真實的開發流程。這不是一個完整的指南,而是基礎知識的概述,所以你可以瞭解 Vue ...
  • 今天自己寫css樣式,其中用到了<ul>標簽,設置了一系列效果後運行,發現位置與設置有出入。chrome上打開檢查項,發現<ul>標簽的styles底部多了以下一段: ul, menu, dir { ul, menu, dir { display: block; list-style-type: d ...
  • 懶載入技術是現在許多大型網站的都使用的提高網站性能的方式,它的核心思想是當用戶想看頁面某個區域時,再載入該區域的數據。這在一定程度上減輕了伺服器端的壓力,也加快了頁面的呈現速度。 其實國內很多網站都用到了懶載入技術,比如國內兩個大型電商網站的頁面都運用到了這項技術: 天貓首頁: 京東商品列表頁: 最 ...
  • 前言: 關於前端的第二篇博客,會寫關於css的,內容比較基礎。寫完這篇博客,會做一個類似美樂樂傢具的界面。good luck to me~ 一、css-引用樣式 標簽上設置style屬性: 引用樣式的三種方式: 第一種:在<body>直接定義與引用樣式 第二種: 在<head>頭部加上下麵代碼(類似 ...
  • 兩個部分,一個是如題的直接上代碼;二是外一則的小體會。 2.js裡面的this對象 var A={a:function(e){alert(e)},b:function(){console.log(this);this.a(1)}} A.b();//直接這樣調用不報錯,控制台裡面看到this是一個有a ...
  • 頁面DOM里的每個節點上都有一個classList對象,程式員可以使用裡面的方法新增、刪除、修改節點上的CSS類。使用classList,程式員還可以用它來判斷某個節點是否被賦予了某個CSS類。 添加類(add) 為 <div> 元素添加多個類: 移除類(remove) 使用remove方法,你可以 ...
  • 轉載網址:http://www.jb51.net/css/529846.html 前言 其實不管是三欄佈局還是兩欄佈局都是我們在平時項目里經常使用的,也許你不知道什麼事三欄佈局什麼是兩欄佈局但實際已經在用,或許你知道三欄佈局的一種或兩種方法,但實際操作中也只會依賴那某一種方法,本文具體的介紹了三欄布 ...
  • 如果你是一個人在自學前端開發,或者是對前端開發有比較濃厚的興趣正想踏入前端領域,只要你在前端自學路上遇到了自己無法解決的技術難題,那麼儘管將你的疑惑交給我的小伙伴兒們吧,我們都是一群在前端自學路上摸爬滾打的有志青年,希望你可以來和我們共同交流。同時也希望你能獻出自己的一份力,幫助我的小伙伴兒們解決他 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...