js刪除數組指定元素

一:javascript

var a = new Array("a","b","cc","d3");
//刪除a數組的cc元素
 
 
//jQuery.inArray()函數用於在數組中搜索指定的值,並返回其索引值。若是數組中不存在該值,則返回 -1。
該函數屬於全局jQuery對象。 jquery 1.2中添加的該靜態方法
var index = $.inArray("cc",a);
 
if(index>=0){
//arrayObject.splice(index,howmany,item1,.....,itemX)
 
//參數    描述
//index  必需。整數,規定添加/刪除項目的位置,使用負數可從數組結尾處規定位置。
//howmany 必需。要刪除的項目數量。若是設置爲 0,則不會刪除項目。
//item1, ..., itemX 可選。向數組添加的新項目。
  a.splice(index,1);
  alert(a.toString());
}else{
  alert("error");
  return false;
}

二:java

Array.prototype.indexOf = function(val) {
            for (var i = 0; i < this.length; i++) {
                if (this[i] == val) return i;
            }
            return -1;
        };
        Array.prototype.remove = function(val) {
            var index = this.indexOf(val);
            if (index > -1) {
                this.splice(index, 1);
            }
        };

        var array = [1, 2, 3, 4, 5];
        array.remove(3);

三:數組jquery

shift:刪除原數組第一項,並返回刪除元素的值;若是數組爲空則返回undefined 
var a = [1,2,3,4,5]; 
var b = a.shift(); //a:[2,3,4,5]   b:1 

unshift:將參數添加到原數組開頭,並返回數組的長度 
var a = [1,2,3,4,5]; 
var b = a.unshift(-2,-1); //a:[-2,-1,1,2,3,4,5]   b:7 
注:在IE6.0下測試返回值總爲undefined,FF2.0下測試返回值爲7,因此這個方法的返回值不可靠,須要用返回值時可用splice代替本方法來使用。 

pop:刪除原數組最後一項,並返回刪除元素的值;若是數組爲空則返回undefined 
var a = [1,2,3,4,5]; 
var b = a.pop(); //a:[1,2,3,4]   b:5 //不用返回的話直接調用就能夠了

push:將參數添加到原數組末尾,並返回數組的長度 
var a = [1,2,3,4,5]; 
var b = a.push(6,7); //a:[1,2,3,4,5,6,7]   b:7 

concat:返回一個新數組,是將參數添加到原數組中構成的 
var a = [1,2,3,4,5]; 
var b = a.concat(6,7); //a:[1,2,3,4,5]   b:[1,2,3,4,5,6,7] 

splice(start,deleteCount,val1,val2,...):從start位置開始刪除deleteCount項,並從該位置起插入val1,val2,... 
var a = [1,2,3,4,5]; 
var b = a.splice(2,2,7,8,9); //a:[1,2,7,8,9,5]   b:[3,4] 
var b = a.splice(0,1); //同shift 
a.splice(0,0,-2,-1); var b = a.length; //同unshift 
var b = a.splice(a.length-1,1); //同pop 
a.splice(a.length,0,6,7); var b = a.length; //同push 

reverse:將數組反序 
var a = [1,2,3,4,5]; 
var b = a.reverse(); //a:[5,4,3,2,1]   b:[5,4,3,2,1] 

sort(orderfunction):按指定的參數對數組進行排序 
var a = [1,2,3,4,5]; 
var b = a.sort(); //a:[1,2,3,4,5]   b:[1,2,3,4,5] 

slice(start,end):返回從原數組中指定開始下標到結束下標之間的項組成的新數組 
var a = [1,2,3,4,5]; 
var b = a.slice(2,5); //a:[1,2,3,4,5]   b:[3,4,5] 

join(separator):將數組的元素組起一個字符串,以separator爲分隔符,省略的話則用默認用逗號爲分隔符 
var a = [1,2,3,4,5]; 
var b = a.join("|"); //a:[1,2,3,4,5]   b:"1|2|3|4|5"

再給個利用數組模擬javaStringBuffer處理字符串的方法:

/**
* 字符串處理函數
*/
function StringBuffer()
{
var arr = new Array;
this.append = function(str)
{
    arr[arr.length] = str; 
};

this.toString = function()
{
    return arr.join(""); //把append進來的數組ping成一個字符串
};
}

今天在應用中忽然發現join是一種把數組轉換成字符串的好方法,故封裝成對象使用了:

/**
* 把數組轉換成特定符號分割的字符串
*/
function arrayToString(arr,separator)
{
if(!separator) separator = "";//separator爲null則默認爲空
    return arr.join(separator); 
}

/**
* 查找數組包含的字符串
*/
function arrayFindString(arr,string)
{
var str = arr.join(""); 
    return str.indexOf(string); 
}
相關文章
相關標籤/搜索