javascript中刪除指定數(shù)組中指定的元素的代碼
更新時間:2011年02月12日 20:54:06 作者:
已知一個數(shù)組,我們想用指定的方法對數(shù)組中的元素進行逐一操作。需要的朋友可以參考下。
函數(shù)如下:
foreach = function (obj, insp){
if(obj== null && obj.constructor != Array){
return [];
}
//obj是要處理的數(shù)組,obj==null 表示對象尚未存在;obj.constructor != Array 表示對象obj的屬性的構造函數(shù)不是數(shù)組;
//constructor屬性始終指向創(chuàng)建當前對象的構造函數(shù)。兩個條件均滿足,則返回空數(shù)組[];
//下面對constructor屬性作進一步了解。
var obj= [1, 2, 3, 4]; // 等價于 var obj= new Array(1, 2, 3, 4);
console.log(obj.constructor === Array); // 返回true 表明obj的構造函數(shù)為Array;
var foo= function() { }; // 等價于 var foo = new Function();
console.log(foo.constructor === Function); // 返回true 表明foo的構造函數(shù)為Function;
var obj = new Foo(); //由構造函數(shù)實例化一個obj對象
console.log(obj.constructor === Foo); // 返回true 表明obj的構造函數(shù)為Foo;
-----------------------------------------------------------------------------------------------------------
var i=0, len = obj.length, r = [];
while(i<len){
var x = insp(obj[i], i);
if (x !== null) {
r[r.length] = x;
}
i++;
}
return r;
};
//對數(shù)組對象obj進行遍歷,參數(shù)insp代表一個方法或函數(shù),用于對obj中的每個元素進行操作。給參數(shù)insp傳遞了兩個參數(shù),obj[i]代表數(shù)組中的每一個元素值;并將函數(shù)參數(shù)insp賦給x,最終將x值賦給數(shù)組r。
-----------------------------------------------------------------------------------------------------------
比如我們要遍歷數(shù)組中的每一個元素,引用foreach函數(shù)
var testArray = [1,2,3,4,5,1,2,'w'];
foreach(testArray, function(i){
alert(i)
});
-----------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------
我們用另一個函數(shù)來刪除指定數(shù)組中指定的元素;
ArrayWithout = function(){
if (arguments.length < 2) {
// Arguments 是特殊的對象,代表函數(shù)的參數(shù).
return arguments.length == 1 ? arguments[0] : null;
}
var results = [];
var aa = arguments[0];
//將第一參數(shù)賦給數(shù)組aa;
if (aa === null || aa.constructor != Array) {
return null;
//如果aa不存在或者不是數(shù)組,那么返回null;
}
if(arguments[1].constructor == Array){
// 如果第二個參數(shù)是數(shù)組,則將參數(shù)數(shù)組中對應的每個元素都刪除;
var args = [];
args[0] = aa;
//aa = arguments[0] 將aa賦給數(shù)組args,作為其第一個元素值;
foreach(arguments[1], function(v, i){
//引用了函數(shù)foreach,來對數(shù)組arguments[1]中每個元素進行操作,
args[i+1] = v;
// v代表數(shù)組arguments[1]中每個元素值,將它們一一賦值給args[1],args[2]...,而args[0]=arguments[0];
});
}
else{
args = arguments;
//如果第二個參數(shù)不是數(shù)組,則直接將參數(shù)數(shù)組賦給args;
}
for(var i = 0;i < aa.length; i ++){
var isWithout = true;
for(var j = 1; j < args.length ; j ++){
if(aa[i] == args[j]){
isWithout = false;
break;
// 切記j是從1開始的,因為args的第一元素args[0]是arguments[0],正是我們要處理的的原數(shù)組,等同于數(shù)組aa;
讓要刪除的各個元素與原數(shù)組aa中的某一元素進行逐次比較,如果相同,break 跳出循環(huán); isWithout返回false,所以也不再執(zhí)行下面的 results.push(aa[i]);
}
}
if (isWithout) {
results.push(aa[i]);
//所謂刪除原理,就是將原數(shù)組各元素與要刪除的元素進行比較,保留與要刪除的元素不相同的元素并賦給一個新的數(shù)組results;
}
}
return results;
//返回已經(jīng)刪除了指定元素的數(shù)組;
};
// 引用ArrayWithout的例子
var testArray = [1,2,3,4,5,1,2,'w'];
var result = ArrayWithout(testArray, 1, 3);
//var result = ArrayWithout(testArray, [1, 4]);
alert(result) //[2,4,5,2]
源代碼如下:
foreach = function (obj, insp){
if(obj == null && obj.constructor != Array){
return [];
}
var i=0, len = obj.length, r = [];
while(i<len){
var x = insp(obj[i], i);
if (x !== null) {
r[r.length] = x;
}
i++;
}
return r;
};
ArrayWithout = function(){
if (arguments.length < 2) {
return arguments.length == 1 ? arguments[0] : null;
}
var results = [];
var aa = arguments[0];
if (aa === null || aa.constructor != Array) {
return null;
}
if(arguments[1].constructor == Array){
var args = [];
args[0] = aa;
foreach(arguments[1], function(v, i){
args[i+1] = v;
});
}
else{
args = arguments;
}
for(var i = 0;i < aa.length; i ++){
var isWithout = true;
for(var j = 1; j < args.length ; j ++){
if(aa[i] == args[j]){
isWithout = false;
break;
}
}
if (isWithout) {
results.push(aa[i]);
}
}
return results;
};
var testArray = [1,2,3,4,5,1,2];
foreach(testArray, function(i){
alert(i)
})
var result = ArrayWithout(testArray, 1, 3);
//var result = ArrayWithout(testArray, [1, 3]);
alert(result) //[2,4,5,2]
復制代碼 代碼如下:
foreach = function (obj, insp){
if(obj== null && obj.constructor != Array){
return [];
}
//obj是要處理的數(shù)組,obj==null 表示對象尚未存在;obj.constructor != Array 表示對象obj的屬性的構造函數(shù)不是數(shù)組;
//constructor屬性始終指向創(chuàng)建當前對象的構造函數(shù)。兩個條件均滿足,則返回空數(shù)組[];
//下面對constructor屬性作進一步了解。
var obj= [1, 2, 3, 4]; // 等價于 var obj= new Array(1, 2, 3, 4);
console.log(obj.constructor === Array); // 返回true 表明obj的構造函數(shù)為Array;
var foo= function() { }; // 等價于 var foo = new Function();
console.log(foo.constructor === Function); // 返回true 表明foo的構造函數(shù)為Function;
var obj = new Foo(); //由構造函數(shù)實例化一個obj對象
console.log(obj.constructor === Foo); // 返回true 表明obj的構造函數(shù)為Foo;
-----------------------------------------------------------------------------------------------------------
var i=0, len = obj.length, r = [];
while(i<len){
var x = insp(obj[i], i);
if (x !== null) {
r[r.length] = x;
}
i++;
}
return r;
};
//對數(shù)組對象obj進行遍歷,參數(shù)insp代表一個方法或函數(shù),用于對obj中的每個元素進行操作。給參數(shù)insp傳遞了兩個參數(shù),obj[i]代表數(shù)組中的每一個元素值;并將函數(shù)參數(shù)insp賦給x,最終將x值賦給數(shù)組r。
-----------------------------------------------------------------------------------------------------------
比如我們要遍歷數(shù)組中的每一個元素,引用foreach函數(shù)
var testArray = [1,2,3,4,5,1,2,'w'];
foreach(testArray, function(i){
alert(i)
});
-----------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------
我們用另一個函數(shù)來刪除指定數(shù)組中指定的元素;
復制代碼 代碼如下:
ArrayWithout = function(){
if (arguments.length < 2) {
// Arguments 是特殊的對象,代表函數(shù)的參數(shù).
return arguments.length == 1 ? arguments[0] : null;
}
var results = [];
var aa = arguments[0];
//將第一參數(shù)賦給數(shù)組aa;
if (aa === null || aa.constructor != Array) {
return null;
//如果aa不存在或者不是數(shù)組,那么返回null;
}
if(arguments[1].constructor == Array){
// 如果第二個參數(shù)是數(shù)組,則將參數(shù)數(shù)組中對應的每個元素都刪除;
var args = [];
args[0] = aa;
//aa = arguments[0] 將aa賦給數(shù)組args,作為其第一個元素值;
foreach(arguments[1], function(v, i){
//引用了函數(shù)foreach,來對數(shù)組arguments[1]中每個元素進行操作,
args[i+1] = v;
// v代表數(shù)組arguments[1]中每個元素值,將它們一一賦值給args[1],args[2]...,而args[0]=arguments[0];
});
}
else{
args = arguments;
//如果第二個參數(shù)不是數(shù)組,則直接將參數(shù)數(shù)組賦給args;
}
for(var i = 0;i < aa.length; i ++){
var isWithout = true;
for(var j = 1; j < args.length ; j ++){
if(aa[i] == args[j]){
isWithout = false;
break;
// 切記j是從1開始的,因為args的第一元素args[0]是arguments[0],正是我們要處理的的原數(shù)組,等同于數(shù)組aa;
讓要刪除的各個元素與原數(shù)組aa中的某一元素進行逐次比較,如果相同,break 跳出循環(huán); isWithout返回false,所以也不再執(zhí)行下面的 results.push(aa[i]);
}
}
if (isWithout) {
results.push(aa[i]);
//所謂刪除原理,就是將原數(shù)組各元素與要刪除的元素進行比較,保留與要刪除的元素不相同的元素并賦給一個新的數(shù)組results;
}
}
return results;
//返回已經(jīng)刪除了指定元素的數(shù)組;
};
// 引用ArrayWithout的例子
var testArray = [1,2,3,4,5,1,2,'w'];
var result = ArrayWithout(testArray, 1, 3);
//var result = ArrayWithout(testArray, [1, 4]);
alert(result) //[2,4,5,2]
源代碼如下:
復制代碼 代碼如下:
foreach = function (obj, insp){
if(obj == null && obj.constructor != Array){
return [];
}
var i=0, len = obj.length, r = [];
while(i<len){
var x = insp(obj[i], i);
if (x !== null) {
r[r.length] = x;
}
i++;
}
return r;
};
ArrayWithout = function(){
if (arguments.length < 2) {
return arguments.length == 1 ? arguments[0] : null;
}
var results = [];
var aa = arguments[0];
if (aa === null || aa.constructor != Array) {
return null;
}
if(arguments[1].constructor == Array){
var args = [];
args[0] = aa;
foreach(arguments[1], function(v, i){
args[i+1] = v;
});
}
else{
args = arguments;
}
for(var i = 0;i < aa.length; i ++){
var isWithout = true;
for(var j = 1; j < args.length ; j ++){
if(aa[i] == args[j]){
isWithout = false;
break;
}
}
if (isWithout) {
results.push(aa[i]);
}
}
return results;
};
var testArray = [1,2,3,4,5,1,2];
foreach(testArray, function(i){
alert(i)
})
var result = ArrayWithout(testArray, 1, 3);
//var result = ArrayWithout(testArray, [1, 3]);
alert(result) //[2,4,5,2]
您可能感興趣的文章:
- JavaScript中詭異的delete操作符
- js delete 用法(刪除對象屬性及變量)
- Javascript中的delete介紹
- javascript delete 使用示例代碼
- JavaScript delete 屬性的使用
- JavaScript從數(shù)組中刪除指定值元素的方法
- Javascript根據(jù)指定下標或對象刪除數(shù)組元素
- js 刪除數(shù)組的幾種方法小結
- js刪除數(shù)組元素、清空數(shù)組的簡單方法(必看)
- js刪除Array數(shù)組中指定元素的兩種方法
- 基于JavaScript實現(xiàn)移除(刪除)數(shù)組中指定元素
- Javascript remove 自定義數(shù)組刪除方法
- JavaScript使用delete刪除數(shù)組元素用法示例【數(shù)組長度不變】
相關文章
深入淺出webpack教程系列_安裝與基本打包用法和命令參數(shù)詳解
下面小編就為大家?guī)硪黄钊霚\出webpack教程系列_安裝與基本打包用法和命令參數(shù)詳解。小編覺得挺不錯的,現(xiàn)在就想給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09js實現(xiàn)首屏延遲加載實現(xiàn)方法 js實現(xiàn)多屏單張圖片延遲加載效果
這篇文章主要介紹了js實現(xiàn)首屏延遲加載實現(xiàn)方法,以及js實現(xiàn)多屏單張圖片延遲加載效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07