亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

為JS擴展Array.prototype.indexOf引發的問題探討及解決

2019-11-20 22:46:45
字體:
來源:轉載
供稿:網友
Array沒有indexOf方法,這樣在一個數組中查找某個元素的索引時比較麻煩,為了調用方便,于是通過prototype原型擴展了Array.prototype.indexOf(),這樣用起來就比較方便了。但是這個自定義的indexOf在對數組進行遍歷的時候卻出現了問題。

Array沒有indexOf方法,這樣在一個數組中查找某個元素的索引時比較麻煩,為了調用方便,于是通過prototype原型擴展了Array.prototype.indexOf(),這樣用起來就比較方便了。
復制代碼 代碼如下:

Array.prototype.indexOf = function(item) {
for (var i = 0; i < this.length; 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]+"<br/>");
}

本來想輸出這四個人的名字,結果輸出的是什么呢?
輸出的居然是:
//0=張飛
//1=關羽
//2=劉備
//3=呂布
//indexOf=function(item) { for (var i = 0; i < this.length; i++) { if (this[i] == item) return i; } return -1; }
除了把名字打出來以外,還額外輸出了自己擴展的方法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; unlike the in operator, this method does not check down the object's prototype chain
看描述,就是我們想要的東西。
在for...in..里做個 判斷就OK了
復制代碼 代碼如下:

if(a.hasOwnProperty(p)){
document.write(p+"="+a[p]+"<br/>");
}

另外,附上hasOwnProperty用法示例,來源于互聯網:
復制代碼 代碼如下:

function Book(title, author) {
this.title = title;
this.author = author;
}
Book.prototype.price = 9.99;
Object.prototype.copyright = "herongyang.com";
var myBook = new Book("JavaScript Tutorials", "Herong Yang");
// Dumping built-in properties at the base prototype level
document.writeln("/nObject.prototype's built-in properties:");
dumpProperty(Object.prototype, "constructor");
dumpProperty(Object.prototype, "hasOwnProperty");
dumpProperty(Object.prototype, "isPrototypeOf");
dumpProperty(Object.prototype, "toString");
dumpProperty(Object.prototype, "valueOf");
dumpProperty(Object.prototype, "copyright");
// Dumping built-in properties at the my prototype level
document.writeln("/n==================/nBook.prototype's built-in properties:");
dumpProperty(Book.prototype, "constructor");
dumpProperty(Book.prototype, "hasOwnProperty");
dumpProperty(Book.prototype, "isPrototypeOf");
dumpProperty(Book.prototype, "toString");
dumpProperty(Book.prototype, "valueOf");
dumpProperty(Book.prototype, "copyright");
// Dumping built-in properties at the object level
document.writeln("/n==================/nmyBook's built-in properties:");
dumpProperty(myBook, "constructor");
dumpProperty(myBook, "hasOwnProperty");
dumpProperty(myBook, "isPrototypeOf");
dumpProperty(myBook, "toString");
dumpProperty(myBook, "valueOf");
dumpProperty(myBook, "copyright");
function dumpProperty(object, property) {
var inheritance;
if (object.hasOwnProperty(property))
inheritance = "Local";
else
inheritance = "Inherited";
document.writeln(property+": "+inheritance+": "
+object[property]);
}

查看瀏覽器支持javascript到哪個版本:
復制代碼 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>瀏覽器的JavaScript版本支持測試</title>
</head>
<body>
<script language="JavaScript">
//document.write("您的瀏覽器類型:"+navigator.appName+"<br/>");
//document.write("瀏覽器版本:"+navigator.appVersion+"<br/>");
//支持JavaScript1.0的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.0<br/>');
</script>
<script language="JavaScript1.1">
//支持JavaScript1.1的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.1<br/>');
</script>
<script language="JavaScript1.2">
//支持JavaScript1.2的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.2<br/>');
</script>
<script language="JavaScript1.3">
//支持JavaScript1.3的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.3<br/>');
</script>
<script language="JavaScript1.4">
//支持JavaScript1.4的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.4<br/>');
</script>
<script language="JavaScript1.5">
//支持JavaScript1.5的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.5<br/>');
</script>
<script language="JavaScript1.6">
//支持JavaScript1.6的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.6<br/>');
</script>
<script language="JavaScript1.7">
//支持JavaScript1.7的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.7<br/>');
</script>
<script language="JavaScript1.8">
//支持JavaScript 1.8的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.8<br/>');
</script>
<script language="JavaScript1.9">
//支持JavaScript1.9的瀏覽器才能夠執行該腳本
document.write('該瀏覽器支持JavaScript1.9<br/>');
</script>
</body>
</html>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本精品视频在线观看| 91美女高潮出水| 久久久久久这里只有精品| 亚洲电影中文字幕| 日韩www在线| 国产精品久久久久久av| 色吧影院999| 欧美国产日韩免费| 国产精品极品美女粉嫩高清在线| 欧美激情性做爰免费视频| 美女少妇精品视频| 欧美日韩亚洲精品一区二区三区| 欧美洲成人男女午夜视频| 亚洲自拍在线观看| 国产精品久久久久影院日本| 国产精品久久久久久婷婷天堂| 成人午夜两性视频| 国产视频丨精品|在线观看| 日韩在线视频导航| 国内外成人免费激情在线视频| 日韩经典中文字幕在线观看| 久久精品国产成人| 欧美韩国理论所午夜片917电影| 国产精品吹潮在线观看| 成人久久一区二区| 国产精品永久免费观看| 欧美日韩中文字幕综合视频| 欧美激情精品久久久久久大尺度| 亚洲欧洲免费视频| 韩剧1988在线观看免费完整版| 在线视频欧美性高潮| 亚洲大胆人体视频| 国产亚洲激情视频在线| 亚洲一区二区自拍| 91精品国产91久久久久久久久| 亚洲一区亚洲二区亚洲三区| 欧美高清在线播放| 亚洲午夜色婷婷在线| 亚洲精品理论电影| 亚洲国产欧美一区二区三区久久| 国产精品一区二区三区成人| 自拍偷拍亚洲在线| 色777狠狠综合秋免鲁丝| 黑人巨大精品欧美一区二区三区| 红桃视频成人在线观看| 日韩精品中文字幕在线| 欧美性猛交xxxxx免费看| 亚洲影院色在线观看免费| 在线观看日韩欧美| 日韩在线欧美在线| 亚洲精品国产成人| 成人免费福利视频| 亚洲老板91色精品久久| 亚洲欧美精品中文字幕在线| 成人亚洲综合色就1024| 日韩成人在线网站| 国产极品精品在线观看| 国产丝袜一区二区三区免费视频| 国产一区二区三区在线免费观看| 亚洲热线99精品视频| 久久人人爽国产| 热99精品只有里视频精品| 欧美成人免费播放| 成人黄色免费网站在线观看| 国产精品黄色影片导航在线观看| 亚洲人成绝费网站色www| 亚洲第一精品电影| 欧洲美女免费图片一区| 日本欧美一二三区| 国产精品99久久久久久www| 欧美性视频精品| 亚洲人成网站999久久久综合| 欧美在线欧美在线| 欧美激情久久久久| 中文字幕在线看视频国产欧美在线看完整| 夜夜嗨av一区二区三区免费区| 中文字幕日韩专区| 日本中文字幕久久看| 成人444kkkk在线观看| 91久久精品美女| 久久精品美女视频网站| 91干在线观看| 欧美成人午夜激情视频| 日韩美女写真福利在线观看| 欧美肥老太性生活视频| 97国产在线视频| 欧美亚洲国产精品| 日韩精品极品毛片系列视频| 久久精品国产综合| 永久免费毛片在线播放不卡| 国产亚洲精品久久久优势| 亚洲一区二区三区sesese| 97视频免费观看| 91黄色8090| 亚洲成人网久久久| 91精品国产99| 久久久av免费| 国产在线精品成人一区二区三区| 国产日韩欧美中文在线播放| 中文字幕国产亚洲| 俺也去精品视频在线观看| 欧美视频一二三| 欧美国产日韩在线| 国产色婷婷国产综合在线理论片a| 91av在线不卡| 欧美丝袜美女中出在线| 欧洲成人午夜免费大片| 国产欧美欧洲在线观看| 日韩免费av一区二区| 亚洲欧洲免费视频| 亚洲三级av在线| 国产va免费精品高清在线观看| 亚洲美女av黄| 亚洲精品欧美日韩专区| 亚洲第一视频网| 欧美另类极品videosbest最新版本| 亚洲国产精品福利| 中文字幕精品www乱入免费视频| 狠狠躁夜夜躁人人躁婷婷91| 中文字幕精品久久| 国产精品日韩一区| 国产极品jizzhd欧美| 亚洲最新中文字幕| 国产精品色视频| 欧美成人在线免费视频| 日av在线播放中文不卡| 欧美成人手机在线| 亚洲国产精品yw在线观看| 欧美日韩在线视频观看| 亚洲视频网站在线观看| 国产精品久久99久久| 尤物九九久久国产精品的特点| 亚洲网站在线观看| 国产亚洲一区精品| 久久激情视频久久| 国产精品久久久久久久7电影| 久久久久久综合网天天| 国产91精品久| 久久久亚洲欧洲日产国码aⅴ| 亚洲精品自拍偷拍| 91在线观看欧美日韩| 国产精品成人免费电影| 亚洲欧洲日本专区| 久久久在线免费观看| 亚洲第一网站男人都懂| 国产aaa精品| 日韩一区二区三区在线播放| 欧美性生交xxxxxdddd| 日韩动漫免费观看电视剧高清| 亚洲人成网站在线播| 日本免费久久高清视频| 久久天堂av综合合色| 国产视频精品久久久| 18久久久久久| 欧美激情亚洲一区| 精品久久久久久国产| 国产成+人+综合+亚洲欧洲| 精品久久香蕉国产线看观看亚洲| 亚洲91精品在线| 精品伊人久久97| 久久久www成人免费精品| 狠狠综合久久av一区二区小说| 伊人伊成久久人综合网站| 91日本在线视频|