第一種:數組遍歷
function search(arr,dst){
var i = arr.length;
while(i-=1){
if (arr[i] == dst){
return i;
}
}
return false;
}
使用方法:
var a=[1,2,3,4]; search(a,3);//返回2
第二種:indexOf()
var arr=[1,2,3,4] arr.indexOf(2);//返回1
在某些IE版本中,不支持indexOf(),就需要先判斷Array是否有indexOf()方法
var arr=[1,2,3,4]
if (!Array.indexOf){
Array.prototype.indexOf=function(obj){
var i=this.length;
while(i-=1){
if(this[i]==obj){
return i;
}
}return -1;
}
}
arr.indexOf(3);//返回2
三、構造函數
原理就是方法二中兼容IE所采用的方法一樣,構造一個新的函數
Array.prototype.weizhi=function(obj){
var i=this.length;
for(i;i!=0;i-=1){
if(this[i]===obj){
return i;
}
}return false;
}
var arr=[1,2,3,4]
arr.weizhi(3);//返回2
第四種:一個數組 ,分別在另一個數組中的位置(也可以用來檢索一個元素 ,視需求所改變)
<script type="text/javascript">
var array=['a','b','c','d','c'];//總數組
var val = ['a','d']//要檢索的數組
var inde=[];//獲取的下標數組
for(var i=0;i<array.length;i++){
for(var x in val){
if(array[i]==val[x]){
inde.push(i)
}
}
}
console.log(inde);//返回[0, 3]
</script>
