位置: 编程技术 - 正文

JavaScript数组去重的五种方法(javascript数组去重函数)

编辑:rootadmin

推荐整理分享JavaScript数组去重的五种方法(javascript数组去重函数),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript数组去除重复元素,javascript数组去除重复元素,javascript数组去重的几种常见方法,javascript数组去除重复元素,javascript数组去重复,javascript数组去重set方法,javascript数组去重函数,javascript数组去重的几种常见方法,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript数组去重是一个比较常见的需求,解决方法也有很多种,网上都可以找到答案的,下面小编给大家整理了一份关于同类型的数组去重的方法,先给大家介绍下简单实现思路。

思路:

遍历数组,一一比较,比较到相同的就删除后面的

遍历数组,一一比较,比较到相同的,跳过前面重复的,不相同的放入新数组

任取一个数组元素放入新数组,遍历剩下的数组元素任取一个,与新数组的元素一一比较,如果有不同的,放入新数组。

遍历数组,取一个元素,作为对象的属性,判断属性是否存在

1. 删除后面重复的:

2. 这个是常规的方法,比较好理解,如果相同则跳出循环

3. 这个我花了好长时间明白的,这里j循环虽然继续了,但是i值已经改变了。就等于是一个新的i循环:

4. 保证新数组中的都是唯一的

5. 用对象属性

javascript数组对象的3个属性

1、length 属性

Length属性表示数组的长度,即其中元素的个数。因为数组的索引总是由0开始,所以一个数组的上下限分别是:0和length-1。和其他大多数语言不同的是,JavaScript数组的length属性是可变的,这一点需要特别注意。当length属性被设置得更大时,整个数组的状态事实上不会发生变化,仅仅是length属性变大;当length属性被设置得比原来小时,则原先数组中索引大于或等于length的元素的值全部被丢失。下面是演示改变length属性的例子:

var arr=[,,5,3,,,,,,];

//定义了一个包含个数字的数组

alert(arr.length); //显示数组的长度

arr.length=; //增大数组的长度

alert(arr.length); //显示数组的长度已经变为

alert(arr[8]); //显示第9个元素的值,为

JavaScript数组去重的五种方法(javascript数组去重函数)

arr.length=5; //将数组的长度减少到5,索引等于或超过5的元素被丢弃

alert(arr[8]); //显示第9个元素已经变为"undefined"

arr.length=; //将数组长度恢复为

alert(arr[8]); //虽然长度被恢复为,但第9个元素却无法收回,显示"undefined"

由上面的代码我们可以清楚的看到length属性的性质。但length对象不仅可以显式的设置,它也有可能被隐式修改。JavaScript中可以使用一个未声明过的变量,同样,也可以使用一个未定义的数组元素(指索引超过或等于length的元素),这时,length属性的值将被设置为所使用元素索引的值加1。例如下面的代码:

代码中同样是先定义了一个包含个数字的数组,通过alert语句可以看出其长度为。随后使用了索引为的元素,将其赋值为,即arr[]=,这时再用alert语句输出数组的长度,得到的是。无论如何,对于习惯于强类型编程的开发人员来说,这是一个很令人惊讶的特性。事实上,使用new Array()形式创建的数组,其初始长度就是为0,正是对其中未定义元素的操作,才使数组的长度发生变化。

由上面的介绍可以看到,length属性是如此的神奇,利用它可以方便的增加或者减少数组的容量。因此对length属性的深入了解,有助于在开发过程中灵活运用。

2、prototype 属性

返回对象类型原型的引用。prototype 属性是 object 共有的。

objectName.prototype

objectName 参数是object对象的名称。

说明:用 prototype 属性提供对象的类的一组基本功能。 对象的新实例“继承”赋予该对象原型的操作。

对于数组对象,以以下例子说明prototype 属性的用途。

给数组对象添加返回数组中最大元素值的方法。要完成这一点,声明一个函数,将它加入 Array.prototype, 并使用它。

该代码执行后,y 保存数组 x 中的最大值,或说 6。

3、constructor 属性

表示创建对象的函数。

object.constructor //object是对象或函数的名称。

说明:constructor 属性是所有具有 prototype 的对象的成员。它们包括除 Global 和 Math 对象以外的所有 JScript 固有对象。constructor 属性保存了对构造特定对象实例的函数的引用。

例如:

以上内容就是关于本文给大家介绍的JavaScript数组去重的五种方法及javascript数组对象的三个属性,希望大家喜欢。

js如何实现淡入淡出效果 淡入淡出效果,在日常项目中经常用到,可惜原生JS没有类似的方法,而有时小的页面并不值得引入一个jQuery库,所以就自己写了一个,已封装,有用得

javascript中的altKey 和 Event属性大全 下面给大家介绍javascript中altkey属性,具体介绍如下所示:altKey属性的定义和用法:此属性返回一个布尔值。指示在指定的事件发生时,Alt键是否被按下并

JS实现的N多简单无缝滚动代码(包含图文效果) 本文实例讲述了JS实现的N多简单无缝滚动代码。分享给大家供大家参考,具体如下:实现原理很简单,注册事件之后,立即将元素的innerHTML累加一次。

标签: javascript数组去重函数

本文链接地址:https://www.jiuchutong.com/biancheng/383675.html 转载请保留说明!

上一篇:javascript实现tab切换的两个实例(javascript tab切换)

下一篇:js如何实现淡入淡出效果(js设置)

  • 折旧年限与税法有关吗
  • 税务机关帮我预填了申报数据,我是不是就不用申报了?
  • 企业投资收益要交哪些税
  • 专票遗失后可以作废吗
  • 自己打印raz
  • 发票开做红冲的会计分录怎么做
  • 2018年度企业所得税税率表
  • 私营企业实行固定税率
  • 公司买了商品做活动会计分录
  • 本行给企业发放贷款收回利息分录?
  • 代交社保费会计账务处理
  • 小规模公司退税
  • 流动资产投资的特点有
  • 客户已经抵扣的发票怎么开负数发票给对方
  • 增值税发票暂时无法查看怎么回事
  • 个人所得税申报方式选哪个
  • 应交税费不核算
  • 税控盘锁死还能报税吗
  • 收派服务费入什么科目
  • 增加注册资本需要多少股东通过
  • 财会【2016】22号文
  • 个人机械租赁费税率
  • 纳税申报表未开票收入可以填负数吗
  • 开办费摊销时间税法规定
  • 固定资产折旧年限的最新规定2023
  • 工程收入怎么算
  • 买入返售金融资产是资产还是负债
  • 租金税率9%和5
  • 递延收益在现金流量表体现吗
  • 用车平台服务费怎么入账
  • php中删除文件的函数
  • 应付税款法账务处理
  • mac键盘快捷键设置
  • 存货周转材料报废处理会计分录
  • php实战开发教程
  • 税收筹划的原则包括
  • uni app面试题
  • php编程计算日期怎么算
  • 预算会计组成体系不包括
  • err03 failed to
  • vue路由传参的几种方式
  • 税控盘抵扣怎么做账
  • 公司进项不够怎么开发票
  • 大型广告牌制作材料
  • 网上怎么申请增驾摩托车
  • 小规模纳税人购进农产品可以抵扣进项税吗
  • 核定征收企业注册
  • 企业所得税的营业收入怎么填
  • 计提缴纳企业所的会计分录怎么写
  • sqlserver2008导出表结构和表数据
  • 股东退股如何清算表格
  • 管理费用冲减其他应付款分录
  • 建筑行业普票和专票的税率一样吗
  • 对于产品开发阶段的评价
  • 购买原材料没有发票能入库吗
  • 研发支出资本化计入什么科目
  • 附加税 减免
  • 公司库存商品科目余额太大怎么办
  • 人工安装费是几个点税税率
  • 房租费计提如何入账
  • 公司向员工个人借款怎么处理
  • mysql的分区表
  • sql2008r2镜像
  • csrss exe
  • mac计算器快捷键
  • macbookair扫描文件怎么弄
  • win8锁定屏幕
  • linux系统怎么查看防火墙状态
  • cocos2d-js-min.js
  • unity3d官方教程
  • prize draw是什么意思
  • python3使用PyMysql连接mysql数据库实例
  • jquery点击复制
  • jquery使用什么方法隐藏元素
  • 堆栈模式都是什么意思
  • js实现无限循环
  • 重庆电子税务局app下载
  • 公务员副处级工资待遇
  • 社保在线审核
  • 计提缴纳城建税分录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设