1. 程式人生 > >JavaScript刪除陣列的某個或某些元素、js替換陣列的某些元素

JavaScript刪除陣列的某個或某些元素、js替換陣列的某些元素

轉自https://www.jb51.net/article/134312.htm
刪除陣列指定的某個元素

首先可以給JS的陣列物件定義一個函式,用於查詢指定的元素在陣列中的位置,即索引,程式碼為:

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 emp = ['abs','dsf','sdf','fd']

假如我們要刪除其中的 ‘fd’ ,就可以使用:

emp.remove('fd')

刪除的陣列的某一項

splice(index,len,[item]) ,該方法會改變原始陣列。

splice有3個引數,它也可以用來替換/刪除/新增陣列內某一個或者幾個值

index:陣列開始下標 len: 替換/刪除的長度 item:替換的值,刪除操作的話 item為空

如:arr = [‘a’,’b’,’c’,’d’]

刪除

//刪除起始下標為1,長度為1的一個值(len設定1,如果為0,則陣列不變)

var arr = ['a','b','c','d']
arr.splice(1,1)
console.log(arr)
//['a','c','d']

//刪除起始下標為1,長度為2的一個值(len設定2)

var arr2 = ['a','b','c','d'] 
arr2.splice(1,2)
console.log(arr2)
//['a','d']

替換

//替換起始下標為1,長度為1的一個值為‘ttt’,len設定的1

var arr = ['a'
,'b','c','d'] arr.splice(1,1,'ttt') console.log(arr) //['a','ttt','c','d'] var arr2 = ['a','b','c','d'] arr2.splice(1,2,'ttt') console.log(arr2) //['a','ttt','d'] 替換起始下標為1,長度為2的兩個值為‘ttt',len設定的1

新增 —- len設定為0,item為新增的值

var arr = ['a','b','c','d']; 
arr.splice(1,0,'ttt'); 
console.log(arr);   
//['a','ttt','b','c','d'] 表示在下標為1處新增一項'ttt'
//delete方法刪除掉陣列中的元素後,會把該下標出的值置為undefined,陣列的長度不會變

var arr = ['a','b','c','d']; 
delete arr[1]; 
arr; 
//["a", undefined × 1, "c", "d"] 中間出現兩個逗號,陣列長度不變,有一項為undefined