IE下很多Array的方法都不被支持。每次都要写。所以记下来,以免忘记:

以下是对Array的一些扩展,在FF ,google 下是不需要加的。

/**
 * 方法Array.filter(function(item,index,array){})
 * 功能:迭代数组.
 * 参数:判断方法function(item,index,array),{item:元素,index:元素索引,array:数组自身}.
 * 返回:为每一个元素运行参数函数,保存所有返回true的元素组成的数组并返回.
 */
Array.prototype.filter = function(param){
    try{
        var arrLength = this.length;
        var resultArr = new Array();
        for(var i = 0; i < arrLength; i++){
            var item = this[i];
            if(param(item,i,this)){
                resultArr.push(this[i]);
            }
        }
        return resultArr;
    }catch(err){
        var txt = "Array.filter存在一个错误。\n\n";
        txt += "错误描述:"+err.description+"\n\n";
        txt += "点击确定继续。\n\n";
        alert(txt);
    }
    
}

/*
* 方法:Array.removeAt(Index)
* 功能:删除数组元素.
* 参数:Index删除元素的下标.
* 返回:在原数组上修改数组
*/

Array.prototype.removeAt=function(Index)
{
   if(isNaN(Index)||Index>this.length){return false;}
   for(var i=0,n=0;i<this.length;i++)
   {
    if(this[i]!=this[Index])
    {
       this[n++]=this[i]
    }
   }
   this.length-=1
}
            
/*                           
* 方法:Array.remove(obj)    
* 功能:删除数组元素.       
* 参数:要删除的对象.   
* 返回:在原数组上修改数组  
*/                          
                              
Array.prototype.remove=function(obj)
{
   if(null==obj){return;}
   for(var i=0,n=0;i<this.length;i++)
   {
    if(this[i]!=obj)
    {
     this[n++]=this[i];
    }
   }
   this.length-=1
}

/*                           
* 方法:Array.Contains(obj)    
* 功能:确定某个元素是否在数组中.       
* 参数:要查找的Object对象
* 返回:找到返回true,否则返回false;
*/                                               
Array.prototype.Contains=function(obj)
{
   if(null==obj){return;}
   for(var i=0,n=0;i<this.length;i++)
   {
    if(this[i]==obj)
    {
     return true;
    }
   }
 
   return false;
}

/*                           
* 方法:Array.IndexOf(obj)    
* 功能:搜索指定的Object,并返回第一个匹配项从零开始的索引       
* 参数:要查找的Object对象  
* 返回:找到返回该元素在数组中的索引,否则返回-1
*/
Array.prototype.indexOf=function(obj)
{
   if(null==obj){return;}
   {
    for(var i=0,n=0;i<this.length;i++)
    {
     if(this[i]==obj)
     {
      return i;
     }
    }   
   }
 
   return -1;
}

/*                           
* 方法:Array.Clear()    
* 功能:消空数组元素.       
* 参数:无.   
* 返回:空数组
*/
Array.prototype.Clear=function()                                   
{                                                                  
   this.length=0;                                             
}

/**
 * 方法:Array.removeVoidElement()
 * 功能:删除无效的元素(null/"")
 * 参数:无。
 * 返回:在原数组上修改数组
 */
Array.prototype.removeVoidElement=function(){
    for(var i = 0; i < this.length; i++){
        if("" == this[i] || null == this[i] || "null" == this[i]){
            this.remove(this[i]);
        }
    }
}

js中Array的一些扩展的更多相关文章

  1. JS中Array数组的三大属性用法

    原文:JS中Array数组的三大属性用法 Array数组主要有3大属性,它们分别是length属性.prototype属性和constructor属性. JS操作Array数组的方法及属性 本文总结了 ...

  2. String方法,js中Array方法,ES5新增Array方法,以及jQuery中Array方法

    相关阅读:https://blog.csdn.net/u013185654/article/details/78498393 相关阅读:https://www.cnblogs.com/huangyin ...

  3. JS中Array详细用法

    1.数组的创建 var name= new Array(); //创建一个数组 name[0]="zhangsan";   //给数组赋值 name[1]="lisi&q ...

  4. js中array的join和concat的区别

    首先:concat方法定义:concat() 方法用于连接两个或多个数组.该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本.举例说明:1 /*concat()结果返回的是一个数组*/ 2 3 ...

  5. js中Array对象方法详解

    操作方法:concat() slice() splice() concat()方法可以基于当前数组中的所有项创建一个新数组.具体来说,这个方法会创建当前数组一个副本,将接收到参数添加到副本的末尾,最后 ...

  6. Js中Array数组学习总结

    第一次写博客...有点方... 小白一枚(是真的小白),自学前端,下面来说说我在学习过程中总结的一些数组操作,如果说哪有错误,请各位大神多多指出,小的虚心接受. 引用类型分为Object类型(所谓的对 ...

  7. js中Array数组基本方法

    总结:push() 添加元素到数组未尾, 返回数组长度 unshift() 添加元素到数组头部, 返回数组长度 pop() 删除数组未尾元素, 返回删除元素 shift() 删除数组头部元素, 返回删 ...

  8. js中Array数组的属性和方法

    这是我自己整理出来的一些关于Array数组的属性和方法,即查即用. 1.Array.length属性:数组的项数组,始终返回0或者更大的值. 2.instanceof操作符:value instanc ...

  9. 关于JS中array对象的push( )

    push()的参数传的是指针,不是值. var arr = new Array(); var item = 5; arr.push(item); var item = 6; 运行以上代码,arr中的元 ...

随机推荐

  1. C#自定义大小与改变大下的方法

    在用VS的窗体设计器时,我们可以发现控件都是可以拖动的,并且还可以调整大小.怎么在自己的程序中可以使用上述功能呢? 下面的方法值得借鉴! using System; using System.Wind ...

  2. Javascript运用函数计算正方形的面积

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  3. ucos中的三种临界区管理机制

    熟悉ucos,或者读过Jean.J.Labrosse写过的ucos书籍的人,一定会知道ucos中著名的临界区管理宏:OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL(). 同样 ...

  4. 谈谈Memcached与Redis

    1. Memcached简介 Memcached是以LiveJurnal旗下Danga Interactive公司的Bard Fitzpatric为首开发的高性能分布式内存缓存服务器.其本质上就是一个 ...

  5. DuiLib 源码分析之CDuiString

    duilib是一个比较常见的界面库,闲来无事看看别人写的代码,跟自己写的一比, 才看到了差距呀,感觉自己写的乱七八糟,keep moving CduiString是duilib提供的一个字符串类,功能 ...

  6. ArcGIS影像配准与空间配准

    ArcGIS影像配准与空间配准 ArcGIS影像配准与空间配准 地图配准可分为影像配准和空间配准.影像配准的对象是raster图,譬如TIFF图.配准后的图可以保存为ESRI GRID, TIFF,或 ...

  7. Python 启动本地服务

    在 Linux 服务器上或安装了 Python 的机器上,Python自带了一个WEB服务器 SimpleHTTPServer,我们可以很简单的使用  python -m SimpleHTTPServ ...

  8. 程序设计入门——C语言 第6周编程练习 1 分解质因数(5分)

    1 分解质因数(5分) 题目内容: 每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数.比如,6可以被分解为2x3,而24可以被分解为2x2x2x3. ...

  9. Opentaps安装小记

    这周了解了个MES项目需求,于是乎找了些开源项目了解下,有php+mysql写的weberp,配置起来相当方便,下一版webERP_v4.13,往F:\Apache\htdocs\一放,启动F:\Ap ...

  10. centos7装机和初步运维

    1.装机-制作U盘启动盘 CentOS7是一个比较新的版本.在服务器领域用得比较多.因为前安装软件可能没有Ubuntu那样方便,所以桌面领域好像不是很多. https://www.centos.org ...