位置: 编程技术 - 正文

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设置)

  • 出口退税退的是进项税还是销项税
  • 增值税专用发票有效期是多长时间
  • 不是党员证明哪些情况需要开
  • 用友财务软件怎么设置二级科目
  • 红字发票信息表填好后再怎么操作
  • 购房所需的税费种类和费用
  • 高新技术企业清算所得税率是多少
  • 营改增是初次分配还是再分配
  • 应收留抵税额退税款科目是资产类
  • 公司注销后应收款能打到法人账户吗
  • 股东借款利息代扣代缴增值税是怎样算的?
  • 租赁车辆保险费用每年都一样吗
  • 公司补贴为什么要交税
  • 原材料投资入股协议约定价值公允价值
  • 固定资产备案怎么备案
  • 餐饮行业原材料
  • 红字记账的四种登记方式
  • 个税跨年的可以补报吗
  • 计提个人负担的社会保险费分录
  • 广告行业监管政策
  • 销项负数发票需要抵扣吗
  • 投资利润率的计算结果不受建设期的长短
  • 开票金额与收入金额有差额可以吗
  • 少计提增值税0.01计入营业外
  • 长期借款利息如何做账
  • linux使用cp
  • 进程aissca.exe
  • wordpress 中文版和国际版区别
  • 网速第一的国家
  • 债券的回购
  • 塔卡夫斯基镜子
  • 不带息票据按面值入账
  • 合伙人资本属于股东吗
  • tensorboard作用
  • php实现上传文件
  • 微信小店api
  • 全网最新的暗号
  • ninja命令使用
  • php 文件目录
  • windows where命令
  • 进货退出进项税额的核算
  • 董事会会议中的会议内容
  • 电子软件是如何诞生的
  • 玩转mongodb4.0从入门到实践
  • 工厂道路设计规范
  • 法人股东的分红怎么算
  • 固定资产减值损失计入
  • 刚开的小公司怎么报税
  • 资本公积的核算维度是什么
  • 商场联营扣点的合作方式
  • 小规模公司用什么成本核算方法
  • 物流公司账务处理流程及方法
  • 其他综合收益 综合收益
  • 酒店酒水成本核算表
  • 应发和实发工资账务处理
  • 年数总和法净残值怎么算
  • sql合并数据库
  • sql两个数据怎么合并到一起
  • mysql 源码 下载
  • Win10预览版拆弹
  • centos安装详细
  • win10更新中途怎么取消
  • linux文件批处理命令
  • linux系统下hosts文件详解及配置
  • Unity3D游戏开发标准教程
  • qt5 opengl
  • 用jquery实现动态添加
  • javascript高级程序设计电子书
  • javascript学习指南
  • js实现功能
  • JavaScript For...In 使用方法
  • jquery的用法
  • jquery ui教程
  • jquery事件委托原理
  • jquery动态改变样式
  • 2023居民医保怎么交
  • 地税是地方税吗
  • 税务局的纳税服务有哪些
  • 年度关联业务往来报告
  • 北京市地方税务局在哪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设