搜尋
首頁web前端js教程為JS擴展Array.prototype.indexOf引發的問題及解決方案_基礎知識

Array沒有indexOf方法,這樣在一個數組中查找某個元素的索引時比較麻煩,為了調用方便,於是透過prototype原型擴展了Array.prototype.indexOf(),這樣用起來就比較方便了。但是這個自訂的indexOf在對陣列進行遍歷的時候卻出現了問題。

複製程式碼 程式碼如下:

Array.prototype.indexOf = function(item) { 
for (var i = 0; i if (this[i] == item) 
return i; 

return -1; 
}

用的時候直接

複製程式碼 程式碼如下:

var arr=[1,2,3,4,5]; 
var index=arr.indexOf(1); //index==0

擴展了以後,用起來很爽很方便,一片和諧景象...

但是某次是遍歷數組元素的時候,使用for..in..循環,引發了其他的問題,打破了這個和諧的氛圍。

複製程式碼 程式碼如下:

var a=["張飛","關羽","劉備","呂布"]; 
for(var p in a){ 
  document.write(p "=" a[p] "
"); 
}

本來想輸出這四個人的名字,結果輸出的是什麼呢?

輸出的居然是:

複製程式碼 程式碼如下:

//0=張飛 
//1=關羽 
//2=劉備 
//3=呂布 
//indexOf=function(item) { for (var i = 0; i

除了把名字打出來以外,還額外輸出了自己擴充的方法indexOf,但是令人瘋狂的是,firefox卻是「正常」的,只有四個人的人名,為什麼會這樣?

輸出indexOf,自己擴充的,可以理解,畢竟for..in是遍歷一個物件的所有使用者定義的屬性或一個陣列的所有元素。

那麼firefox為什麼不會呢?

後來查了資料才明白,

Array在javascript1.6版本已經支援Array.indexOf(),而我用的firefox是3.5版本,已經支援javascript1.8了,indexOf是其Array本身固有的方法了。

而IE,即使我用的是IE8,也才支援到javascript1.3版本。

所以IE8認為indexOf是“使用者定義的屬性”,而firefox認為是自己原生支援的固有的屬性。

真的是這樣嗎?

做個實驗,把indexOf更名為myIndexOf,再試試,結果IE和firefox都輸出myIndexOf,證明前面的觀點是正確。

那麼又來了個問題,我擴充indexOf很久了,現在不少專案的程式碼都已經在使用這個方法,而現在我非要使用for..in輸出陣列本身的元素,不要其他我自己擴充到俄羅斯方法,怎麼辦?

好在javascript提供了hasOwnProperty方法。

看一下其描述:

複製程式碼 程式碼如下:

Every object descended from Object inherits the hasOwnProperty method. This method can be used to determine whether an object has the specified property as a direct property of that object; un​​yke the in operator, this object; notnity the in operator, this object; notnity the in operator, this.
看描述,就是我們想要的東西。

在for...in..裡面做個 判斷就OK了

複製程式碼 程式碼如下:
if(a.hasOwnProperty(p)){ 
            document.write(p "=" a[p] "
"); 
        }

另外,附上hasOwnProperty用法範例,來自網路:

複製程式碼 程式碼如下:

函數書(書名,作者){ 
   this.title = 標題; 
   this.author = 作者; 
  } 
   書本.原型.價格 = 9.99; 
   Object.prototype.copyright = "herongyang.com"; 
   var myBook = new Book("JavaScript 教學", "Herong Yang"); 
   // 在基本原型層級轉儲內建屬性
   document.writeln("/nObject.prototype 的內建屬性:"); 
   dumpProperty(Object.prototype, "建構子"); 
   dumpProperty(Object.prototype, "hasOwnProperty"); 
   dumpProperty(Object.prototype, "isPrototypeOf"); 
   dumpProperty(Object.prototype, "toString"); 
   dumpProperty(Object.prototype, "valueOf"); 
   dumpProperty(Object.prototype, "版權"); 
   // 在我的原型層級轉儲內建屬性
   document.writeln("/n==================/nBook.prototype的內建屬性:"); 
   dumpProperty(Book.prototype, "建構子"); 
   dumpProperty(Book.prototype, "hasOwnProperty"); 
   dumpProperty(Book.prototype, "isPrototypeOf"); 
   dumpProperty(Book.prototype, "toString"); 
   dumpProperty(Book.prototype, "valueOf"); 
   dumpProperty(Book.prototype, "版權"); 
   // 在物件層級轉儲內建屬性
   document.writeln("/n==================/nmyBook的內建屬性:"); 
   dumpProperty(myBook,「建構子」); 
   dumpProperty(myBook, "hasOwnProperty"); 
   dumpProperty(myBook, "isPrototypeOf"); 
   dumpProperty(myBook,“toString”); 
   dumpProperty(myBook, "valueOf"); 
   dumpProperty(myBook, "版權"); 
函數 dumpProperty(物件, 屬性) { 
   var 繼承;  
   if (object.hasOwnProperty(property))  
      繼承=「本地」; 
   否則
      繼承=「繼承」; 
   document.writeln(property ": " 繼承 ": "
      物件[屬性]); 
}

查看瀏覽器支援javascript到哪個版本:

複製程式碼程式碼如下:

ttp://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
http://www.w3.org/1999/xhtml"> 
 
 
  瀏覽器的JavaScript版本支援測試 
  
  
      
     
     
     
     
   
   
   
   
    
  

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
使用C#中的Array.Sort函数对数组进行排序使用C#中的Array.Sort函数对数组进行排序Nov 18, 2023 am 10:37 AM

标题:C#中使用Array.Sort函数对数组进行排序的示例正文:在C#中,数组是一种常用的数据结构,经常需要对数组进行排序操作。C#提供了Array类,其中有Sort方法可以方便地对数组进行排序。本文将演示如何使用C#中的Array.Sort函数对数组进行排序,并提供具体的代码示例。首先,我们需要了解一下Array.Sort函数的基本用法。Array.So

简单明了的PHP array_merge_recursive()函数使用方法简单明了的PHP array_merge_recursive()函数使用方法Jun 27, 2023 pm 01:48 PM

在进行PHP编程时,我们常常需要对数组进行合并。PHP提供了array_merge()函数来完成数组合并的工作,不过当数组中存在相同的键时,该函数会覆盖原有的值。为了解决这个问题,PHP在语言中还提供了一个array_merge_recursive()函数,该函数可以合并数组并保留相同键的值,使得程序的设计变得更加灵活。array_merge

如何使用PHP中的array_combine函数将两个数组拼成关联数组如何使用PHP中的array_combine函数将两个数组拼成关联数组Jun 26, 2023 pm 01:41 PM

在PHP中,有许多强大的数组函数可以使数组的操作更加方便和快捷。当我们需要将两个数组拼成一个关联数组时,可以使用PHP的array_combine函数来实现这一操作。这个函数实际上是用来将一个数组的键作为另一个数组的值,合并成一个新的关联数组。接下来,我们将会讲解如何使用PHP中的array_combine函数将两个数组拼成关联数组。了解array_comb

PHP array_fill()函数用法详解PHP array_fill()函数用法详解Jun 27, 2023 am 08:42 AM

在PHP编程中,数组是一种非常重要的数据结构,能够轻松地处理大量数据。PHP中提供了许多数组相关的函数,array_fill()就是其中之一。本篇文章将详细介绍array_fill()函数的用法,以及在实际应用中的一些技巧。一、array_fill()函数概述array_fill()函数的作用是创建一个指定长度的、由相同的值组成的数组。具体来说,该函数的语法

Python中的Array模块怎么使用Python中的Array模块怎么使用May 01, 2023 am 09:13 AM

Python中的array模块是一个预定义的数组,因此其在内存中占用的空间比标准列表小得多,同时也可以执行快速的元素级别操作,例如添加、删除、索引和切片等操作。此外,数组中的所有元素都是同一种类型,因此可以使用数组提供的高效数值运算函数,例如计算平均值、最大值和最小值等。另外,array模块还支持将数组对象直接写入和读取到二进制文件中,这使得在处理大量数值数据时更加高效。因此,如果您需要处理大量同质数据,可以考虑使用Python的array模块来优化代码的执行效率。要使用array模块,首先需要

java中indexof方法有什么用java中indexof方法有什么用May 17, 2023 pm 02:28 PM

indexof方法:注解:indexOf方法返回一个整数值,指出String对象内子字符串的开始位置。如果没有找到子字符串,则返回-1。publicclassIndexOf{publicstaticvoidmain(String[]args){Strings="李宏#王海#林巧#陆寻#唐梅";Stringq="#";//需要查找的字符串Stringerr="*";//不存在的字符串inti=0;for(intj=0;j

Java中的ArrayStoreException异常的常见原因是什么?Java中的ArrayStoreException异常的常见原因是什么?Jun 25, 2023 am 09:48 AM

在Java编程中,数组是一种重要的数据结构。数组可以在一个变量中存储多个值,更重要的是可以使用索引访问每个值。但是在使用数组时,可能会出现一些异常,其中之一是ArrayStoreException。本文将讨论ArrayStoreException异常的常见原因。1.类型不匹配数组在创建时必须指定元素类型。当我们试图将不兼容的数据类型存储到一个数组中时,就会抛

indexof和includes有哪些区别indexof和includes有哪些区别Nov 24, 2023 pm 01:20 PM

区别有:1、返回值类型不同;2、接受的参数不同;3、对待NaN的方式不同;4、对待大小写的方式不同;5、可以使用的数据类型不同。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器