在現在代浏覽器中判斷一個元素在不在一個數組中,咱們可以用Array對象的indexOf()方法來取得這個元素在當前數組中的索引值,若索引值不等於-1,數組中就存在這個元素,
例如:
var arr = [2,53,23,'test',9,'array'];
//判斷array在不在數組arr中
arr.indexOf('array') !== -1 ? alert('存在') : alert('不存在');
但是IE9以前的版本都不支持此方法,那咱們就只能擴展一個:
代碼如下復制代碼
Array.prototype.indexOf = function(el){
for (var i=0,n=this.length; i<n; i++){
if (this[i] === el){
return i;
}
}
return -1;
}
下面咱們就來檢測一下各個浏覽器的兼容性,代碼如下:
var arr = [2,53,23,'test',9,'array'];
if(!Array.indexOf){
Array.prototype.indexOf = function(el){
for (var i=0,n=this.length; i<n; i++){
if (this[i] === el){
return i;
}
}
return -1;
}
}
arr.indexOf('array') !== -1 ? alert('存在') : alert('不存在');
上面就是用Array的indexOf方法來判斷數組中一個元素是否存在的方法。
Array的原生方法:
concat(): 連接兩個或更多的數組哦
join(): 把數組的所有元素放在一個字符串中
pop():刪除並返回數組的最後一個元素
push():向數組的末尾添加一個元素,並返回數組長度。
reverse():顛倒數組中的元素順序
shift(): 刪除並返回數組的第一個元素。
slice():返回已選定的元素
sort():對數組的元素進行排序
splice():刪除元素,並向數組添加新元素。
toSource():返回該對象的源代碼
toString():把數組轉換為字符串,並返回結果
valueOf():返回數組對象的原始值。