splice() 方法向/從數組中添加/刪除項目,然后返回被刪除的項目。
arrayObject.splice(index,howmany,item1,.....,itemX)
參數 描述
- index 必需。整數,規定添加/刪除項目的位置,使用負數可從數組結尾處規定位置。
- howmany 必需。要刪除的項目數量。如果設置為 0,則不會刪除項目。
- item1, ..., itemX 可選。向數組添加的新項目。
返回值 - Array 包含被刪除項目的新數組,如果有的話。
舉例
- 不刪除插入
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,0,"Lemon","Kiwi");
Banana,Orange,Lemon,Kiwi,Apple,Mango
- 刪除加插入
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,1,"Lemon","Kiwi");
Banana,Orange,Lemon,Kiwi,Mango
- 刪除
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,2);
Banana,Orange
Array.isArray(obj)
Array.isArray() 用於確定傳遞的值是否是一個 Array。
Array.isArray([1, 2, 3]);
// true
Array.isArray({foo: 123});
// false
Array.isArray("foobar");
// false
Array.isArray(undefined);
// false
Polyfill
假如不存在 Array.isArray(),則在其他代碼之前運行下面的代碼將創建該方法。
if (!Array.isArray) {
Array.isArray = function(arg) {
return Object.prototype.toString.call(arg) === '[object Array]';
};
}
instanceof 和 isArray
- 當檢測Array實例時, Array.isArray 優於 instanceof,因為Array.isArray能檢測iframes.
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray(1,2,3); // [1,2,3]
// Correctly checking for Array
Array.isArray(arr); // true
// Considered harmful, because doesn't work though iframes
arr instanceof Array; // false

