位置: 编程技术 - 正文

Javascript数组Array方法解读(JavaScript数组去重)

编辑:rootadmin

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

文章相关热门搜索词:JavaScript数组添加元素,JavaScript数组长度,JavaScript数组排序,JavaScript数组排序,JavaScript数组添加元素,JavaScript数组反转,JavaScript数组删除元素,JavaScript数组反转,内容如对您有帮助,希望把文章链接给更多的朋友!

接上一篇《Javascript数组Array基础介绍》,这一篇详细介绍Array的所有方法。

所有数组的方法都定义在Array.prototype上,而Array.prototype本身也是一个数组。

array.concat()

浅复制一份当前数组,并把接收到的参数附加到新数组的末尾。原数组不改变。

语法

array.concat(value1, value2, ..., valueN)参数为需要合并的数组或非数组值

可以合并数组或非数组值,但是要注意如果包含对象,对象还是引用原来的对象。

array.join()

返回一个将数组所有元素用分隔符拼接成的字符串,默认分隔符为逗号。

语法

array.join(seperator)参数为分割符

当将大量字符串片段组装时,join方法比+元素运算符要快。

利用new Array(3)将生成一个长度为三的空数组,同时结合join()方法,可以实现重复某段字符串。

重复的次数就是数组长度减一,因为字符串是分隔符。

由于数组本身是对象,拥有toString()方法,利用它也能实现将数组拼接成一个字符串,只不过分隔符只能是逗号了。

实际上它会先调用每一个元素的toString()方法。

array.push()

把一个或多个参数附加在数组末尾,返回数组长度。改变数组自身。

语法

array.push(value1, value2, ..., valueN);实例

另一种方法也可以实现在数组末尾插入值。

将数组最后一项删除,并返回删除项。改变数组自身。

如果数组为空,返回undefined。

array.unshift()

把一个或多个参数插入到数组头部,返回数组长度。改变数组自身。

array.shift()

将数组的第一项删除,并返回删除项。改变数组自身。

如果数组为空,返回undefined。

array.sort()

这个方法按照每个元素的toString()方法返回的值进行排序,所以一般得不到期望的结果。

Javascript数组Array方法解读(JavaScript数组去重)

但是sort()方法可以接收一个我们自定义的函数进行比较。比较函数接受两个参数,尤其sort()默认是升序,所以如果想让第一个参数位于第二个参数前面就要返回负数,相等返回0,位于后面返回正数。

比较字符串可以结合string.localeCompare()方法来用。

array.reverse()

反转数组元素顺序,返回数组自身。

array.slice()

对数组浅复制其中的一段,不改变数组自身。

array.slice(start, end);方法接受两个参数,最后一个可以省略,默认是数组自身长度。

如果传入负数,那么会被自动加上数组的长度,试图变成非负数。传入一个绝对值小于数组长度的值,就是从后向前取负数绝对值个数的元素。例如例子中取了后三个元素。

array.splice()

这是数组中最强大也最常用对的方法了,可以实现删除,插入,替换。

语法

array.slice(start, count, item);该方法移除一个或多个元素,并用新的元素替代他们。start是开始的位置,count是删除的数量,item是新增加的元素(item不止一个,也可省略),以数组形式返回删除的元素。

下面介绍一些ECMAScript5新增的方法,主要是ie8不支持。

indexOf() 与 lastIndexOf()

查找对应项在数组中的索引位置,第二个参数表示对应查找方向的起始位置,返回第一个匹配的位置,如果没有找到则返回-1;indexOf()是从前往后查找,lastIndexOf()是从后往前查找。

迭代方法

以下方法接受两个参数,第一个是每一项运行的函数,第二个函数运行的作用域。运行函数有三个参数,分别是当前项,位置,数组本身。

array.every()

运行给定函数,如果迭代每一项都返回true,则最终返回true。

array.some()

运行给定函数,如果迭代中有一项返回true,则最终返回true。

array.map()

运行给定函数,将迭代中返回的值组成数组,返回该数组。

array.filter()

运行给定函数,将迭代中返回true的元素以数组形式返回

array.forEach()

运行给定函数,不返回任何值。类似于普通的for循环的功能。

归并方法

函数接受两个参数,第一个参数是每一个运行的自定义函数,第二项是作为归并基础的初始值。自定义函数接受四个参数,分别是前一项,当前项,位置,数组。

小结

这一篇介绍了数组方法的种种细节和注意问题,下一篇将会介绍数组更高级的用法。本篇后续会添加ECMAScript6 新增加的数组方法的介绍。

JS中创建函数的三种方式及区别 1.函数声明functionsum1(n1,n2){returnn1+n2;};2.函数表达式,又叫函数字面量varsum2=function(n1,n2){returnn1+n2;};两者的区别:解析器会先读取函数声明,并使其在执行

javascript中arguments,callee,caller详解 arguments是什么?arguments是函数调用时,创建的一个类似的数组但又不是数组的对象,并且它存储的是实际传递给函数的参数,并不局限于函数声明的参

javascript 继承学习心得总结 看了不少js继承的东西也该总结总结了。先说一下大概的理解,有不对的还望指正,也好更正一下三观。另外说明下,下面的例子并非原创基本就是改了

标签: JavaScript数组去重

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

上一篇:Javascript数组Array基础介绍(JavaScript数组删除元素)

下一篇:JS中创建函数的三种方式及区别(js中创建函数的方法)

  • 小规模纳税人取得增值税
  • 企业收到退税款怎么处理
  • 公司给个体户转账怎么交税
  • 原材料不良品的处理流程
  • 投资收益转入资本公积
  • 带薪年假是入职就有还是要等一年以后
  • 电子商业汇票怎么兑现
  • 已交的增值税能计入费用吗
  • 建筑企业小型企业有哪些
  • 公司注销留抵税金能退税吗
  • 货物运输时发生车祸
  • 发票认证抵扣了还能冲红么
  • 外商投资企业母公司派到境内职员回国后
  • 收到运输发票需要开票吗
  • 医疗器械销售初次拜访话术
  • 企业所得税成本确认原则
  • 所得税预缴申报表利润
  • 税务行业软件
  • 纳税人如何网上申请预填报服务
  • 长期应付款怎么冲减
  • 三金一费包括哪些
  • 季报小微企业不包括哪些
  • 材料按计划成本计价下,外购材料结算
  • 预收房租费用计入什么科目
  • 借别人资质投标如何签合同
  • 电脑安全系统无法启动怎么办
  • 生产提供什么产品
  • 评估价格是按原值还是净值
  • 由于找不到msvcr120.dll,无法继续执行代码什么意思
  • 税前扣除是好事吗
  • php bcsub
  • PHP:imagetruecolortopalette()的用法_GD库图像处理函数
  • 投资收益怎么做不影响利润
  • 供应商发票多开了怎么处理?
  • vite搭建项目
  • Yii2实现ajax上传图片插件用法
  • php fgetcsv
  • php设置header参数
  • 帝国cms界面
  • 新的企业所得税
  • 关联广告是什么意思
  • 有材料成本差异率怎么算材料成本差异
  • sqlserver2000分页
  • 劳务费发票可以抵扣吗?
  • 固定资产折旧计入什么费用
  • 暂估入库账务处理举例
  • 按利润总额的10%怎么算
  • 存在弃置费用的固定资产由于技术进步
  • 盘亏盘盈的会计处理
  • 工会经费为0是不用申报的?
  • 企业弥补亏损的渠道有哪些
  • 出口退税备案完事了,为什么还没有退税勾选那个模块
  • 开公司合理避税的方法
  • 备用金取多少钱会被监控
  • 销项负数发票怎么冲减成本
  • MySQL中interactive_timeout和wait_timeout的区别
  • 防火墙监视模式
  • centos crond
  • win10系统怎么将桌面路径改为d盘
  • macbookpro中的文本编辑
  • 系统警告设置
  • win 8怎么样
  • 应用程序发生异常如何解决
  • 打开word显示
  • 双win系统怎么删除一个
  • win10预览模式
  • iframe 自适应宽度和高度
  • 爬虫 python
  • unity shaders and effects cookbook
  • 用批处理删除注册表项
  • 安卓开发问题
  • js鼠标点击事件监听
  • ubuntu安装步骤详解
  • python快捷键大全
  • 【Rayeager PX2分享】OpenCV入门之线段检测
  • 安卓登录界面布局设计
  • 运满满订单取消技术服务费退还吗
  • 粮食企业所得税优惠
  • 一年内在两家公司任职个税汇算清缴
  • 浙江网上税务局申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设