js 数组删除和添加数据「建议收藏」

js 数组删除和添加数据「建议收藏」}//新增checkbox选中监听事件table.on(‘checkbox(LAY-team-add)’,function(obj){alert(obj.checked)varid=obj.data.id;if(obj.checked){addCheckbox.push(id);alert(addCheckbox)…

大家好,又见面了,我是你们的朋友全栈君。

}
//新增checkbox选中监听事件
table.on('checkbox(LAY-team-add)', function(obj){
    alert(obj.checked)
    var id=obj.data.id;
    if(obj.checked){
        addCheckbox.push(id);
        alert(addCheckbox)
    }else{
     var index=  addCheckbox.indexOf(id);
        addCheckbox.splice(index, 1);
    }
    alert(addCheckbox)
});

 

JavaScript中数组元素删除的七大方法汇总

原文链接:https://blog.csdn.net/u010323023/article/details/52700770 

在JavaScript中,除了Object之外,Array类型恐怕就是最常用的类型了。与其他语言的数组有着很大的区别,JavaScript中的Array非常灵活。今天我就来总结了一下JavaScript中Array删除的方法。大致的分类可以分为如下几类:

1、length 
2、delete 
3、栈方法 
4、队列方法 
5、操作方法 
6、迭代方法 
7、原型方法

下面我对上面说的方法做一一的举例和解释。

一、length

JavaScript中Array的length属性非常有特点一一它不是只读的。因此,通过设置这个属性可以从数组的末尾移除项或添加新项,请看下面例子:

1 var colors = ["red", "blue", "grey"];   //创建一个包含3个字符串的数组
2 colors.length = 2;
3 console.log(colors[2]);  //undefined

二、delete关键字

1 var arr = [1, 2, 3, 4];
2 delete arr[0];
3 
4 console.log(arr);   //[undefined, 2, 3, 4]

可以看出来,delete删除之后数组长度不变,只是被删除元素被置为undefined了。

三、栈方法

1 var colors = ["red", "blue", "grey"];
2 var item = colors.pop();
3 console.log(item);      //"grey"
4 console.log(colors.length);    //2

可以看出,在调用Pop方法时,数组返回最后一项,即”grey”,数组的元素也仅剩两项。

四、队列方法

队列数据结构的访问规则是FIFO(先进先出),队列在列表的末端添加项,从列表的前端移除项,使用shift方法,它能够移除数组中的第一个项并返回该项,并且数组的长度减1。

1 var colors = ["red", "blue", "grey"];
2 var item = colors.shift();
3 console.log(item);      //"red"
4 console.log(colors.length);    //2

五、操作方法 
splice()恐怕要算最强大的数组方法了,他的用法有很多种,在此只介绍删除数组元素的方法。在删除数组元素的时候,它可以删除任意数量的项,只需要指定2个参数:要删除的第一项的位置和要删除的项数,例如splice(0, 2)会删除数组中的前两项。

1 var colors = ["red", "blue", "grey"];
2 var item = colors.splice(0, 1);
3 console.log(item);      //"red"
4 console.log(colors);    //["blue", "grey"]

六、迭代方法

所谓的迭代方法就是用循环迭代数组元素发现符合要删除的项则删除,用的最多的地方可能是数组中的元素为对象的时候,根据对象的属性例如ID等等来删除数组元素。下面介绍两种方法:

第一种用最常见的ForEach循环来对比元素找到之后将其删除:

复制代码

var colors = ["red", "blue", "grey"];

colors.forEach(function(item, index, arr) {
    if(item == "red") {
        arr.splice(index, 1);
    }
});

复制代码

第二种我们用循环中的filter方法:

复制代码

1 var colors = ["red", "blue", "grey"];
2 
3 colors = colors.filter(function(item) {
4     return item != "red"
5 });
6 
7 console.log(colors);    //["blue", "grey"]

复制代码

代码很简单,找出元素不是”red”的项数返回给colors(其实是得到了一个新的数组),从而达到删除的作用。

七、原型方法

通过在Array的原型上添加方法来达到删除的目的:

复制代码

 1 Array.prototype.remove = function(dx) {
 2 
 3     if(isNaN(dx) || dx > this.length){
 4         return false;
 5     }
 6 
 7     for(var i = 0,n = 0;i < this.length; i++) {
 8         if(this[i] != this[dx]) {
 9             this[n++] = this[i];
10         }
11     }
12     this.length -= 1;
13 };
14 
15 var colors = ["red", "blue", "grey"];
16 colors.remove(1);
  console.log(colors); //["red", "grey"]

复制代码

在此把删除方法添加给了Array的原型对象,则在此环境中的所有Array对象都可以使用该方法。尽管可以这么做,但是我们不推荐在产品化的程序中来修改原生对象的原型。道理很简单,如果因某个实现中缺少某个方法,就在原生对象的原型中添加这个方法,那么当在另一个支持该方法的实现中运行代码时,就可能导致命名冲突。而且这样做可能会意外的导致重写原生方法。

 

默默搬砖中 ——假装自己是小白

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134505.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 制作WIN7+XP+DOS+PE多系统启动光盘

    制作WIN7+XP+DOS+PE多系统启动光盘本文详细介绍了怎样制作自定义的多系统启动光盘的流程,从零开始!达到完成系统盘制作的目的。

    2022年7月26日
    17
  • Angular 2 前端 http 传输 model 对象及其外键的问题

    Angular 2 前端 http 传输 model 对象及其外键的问题

    2021年11月24日
    47
  • Canary保护

    Canary保护之前做题没做过 canary 类型 今天补知识盲点遇到 canary 恰好也写一篇吧 学 pwn 时基本会遇到几种保护类型 如 RELRO PIE NX 还有 Canary 这里解释一下 canary 栈溢出保护是一种缓冲区溢出攻击缓解手段 当函数存在缓冲区溢出攻击漏洞时 攻击者可以覆盖栈上的返回地址来让 shellcode 能够得到执行 当启用栈保护后 函数开始执行的时候会先往栈里插入 cookie 信息 当函数真正返回的时候会验证 cookie 信息是否合法 如果不合法就停止程序运行 攻击者在覆盖返回地址的时候往往也会将 c

    2026年1月16日
    1
  • 基于豆瓣影评数据的文本分析系统【数据爬取+数据清洗+数据库存储+LDA主题挖掘+词云可视化】「建议收藏」

    基于豆瓣影评数据的文本分析系统【数据爬取+数据清洗+数据库存储+LDA主题挖掘+词云可视化】「建议收藏」本分析中很多的工作都是基于评论数据来进行的,比如:滴滴出行的评价数据、租房的评价数据、电影的评论数据等等,从这些语料数据中能够挖掘出来客户群体对于某种事物或者事情的看法,较为常见的工作有:舆情分析、热点挖掘和情感分析。如果想要了解关于文本分类或者是情感分析相关的工作内容,可以阅读我的《数据建模实战》专栏文章,下面是链接信息:…

    2022年5月10日
    42
  • 一篇文章,教你彻底搞懂selenium的工作原理

    一篇文章,教你彻底搞懂selenium的工作原理

    2021年5月24日
    215
  • WordPress建站_如何建设社区

    Wordpress建站_如何建设社区创始人或建设者,您需要了解将社区集成到您的项目中的哪些内容?采用什么样的去中心化的方式?”在2020年之前,我花了很多时间分析中心化社区建设最佳实践的来龙去脉,主要来自我作为用户(Foursquare、Meetup、Twitter),作为一名员工(StackOverflow),或者在我在UnionSquareVentures期间通过渗透了解到的成功Web2网络示例。…

    2022年10月2日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号