日期:2014-05-16  浏览次数:20375 次

javascript 清除数组中的空元素
最近在干活的时候发现数组中有空元素,根据需求,要删除这个空元素,可惜的是,javascript并没有提供这么一个方法,找了很多的解决办法,发现都是自己实现的一个函数,以下是我找到的两种方法:
第一种:
Array.prototype.clean = function(deleteValue) {
  for (var i = 0; i < this.length; i++) {
    if (this[i] == deleteValue) {         
      this.splice(i, 1);//返回指定的元素
      i--;
    }
  }
  return this;
};

以上方法是为Array对象添加了一个clean方法,方法的功能是清楚指定的元素,那么,如果我们想清除一个空元素的话,可以将这个空元素 ''传递给array,看下例子:
test = new Array("","One","Two","", "Three","","Four").clean("");
test2 = [1,2,,3,,3,,,,,,4,,4,,5,,6,,,,];
test2.clean(undefined);


第二种:
var arr = [1,2,,3,,3,,,0,,,4,,4,,5,,6,,,,];
arr = arr.filter(function(n){return n}); // (javascript 1.6 and above)
arr // [1, 2, 3, 3, 4, 4, 5, 6]


以上方法用的是javascrript的filter函数,用法:
var filteredArray = array.filter(callback);

对数组中的每个元素都执行一次指定的函数(callback),并且创建一个新的数组,该数组元素是所有回调函数执行时返回值为 true 的原数组元素。它只对数组中的非空元素执行指定的函数,没有赋值或者已经删除的元素将被忽略,同时,新创建的数组也不会包含这些元素。就是说,这个函数会利用已有的数组元素来创建新的数组,但是新的数组中的元素只能是已有数组中非空的元素或者已经赋值的元素。