本文實例講述了js操作數組函數。分享給大家供大家參考,具體如下:
1.刪除數組中指定的元素
/** * 參考實例 foreach = function (obj, insp){ if(obj== null && obj.constructor != Array){ return []; } //obj是要處理的數組,obj==null 表示對象尚未存在;obj.constructor != Array 表示對象obj的屬性的構造函數不是數組; //constructor屬性始終指向創建當前對象的構造函數。兩個條件均滿足,則返回空數組[]; //下面對constructor屬性作進一步了解。 var obj= [1, 2, 3, 4]; // 等價於 var obj= new Array(1, 2, 3, 4); console.log(obj.constructor === Array); // 返回true 表明obj的構造函數為Array; var foo= function() { }; // 等價於 var foo = new Function(); console.log(foo.constructor === Function); // 返回true 表明foo的構造函數為Function; var obj = new Foo(); //由構造函數實例化一個obj對象 console.log(obj.constructor === Foo); // 返回true 表明obj的構造函數為Foo; */ //刪除數組中指定的元素 function del(val, arr) { //檢測參數 if (arr == null && arr.constructor != Array) { return []; } var newarr = []; //不存在的保存到新數組中 for (var i = 0; i < arr.length; i++) { if (arr[i] != val) newarr.push(arr[i]); } return newarr; } alert(del(2, [1, 2, 3, 4, 5, 2]));
2.去除重復的元素
/** *去除數組中重復的元素 把元素的值存為一個新數組的key,key是不可以重復的,然後變量次數組即可 */ function unique(data) { data = data || []; var a = {}; len = data.length; for (var i = 0; i < len; i++) { var v = data[i]; if (typeof(a[v]) == 'undefined') { a[v] = 1; } }; data.length = 0; for (var i in a) { data[data.length] = i; } return data; } alert(unique([12,12,12,34]));
3.刪除數組指定下標的元素
/** *刪除數組的指定下標元素 * * i 的值是一直在變的,n的值是只有if條件成立的時候才會變(會依次遞增) */ Array.prototype.remove=function(dx) { if(isNaN(dx)||dx>this.length){return false;} for(var i=0,n=0;i<this.length;i++) { if(this[i]!=this[dx]) { this[n++]=this[i] } } this.length-=1 } var arr = [1,2,3,4,2,5]; alert(arr); arr.remove(2); alert(arr);
希望本文所述對大家JavaScript程序設計有所幫助。