百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

js数组常用方法总结(js数组的使用)

wptr33 2025-03-14 21:29 30 浏览

首先说明,本文没技术含量,都是js的知识,只是为以后查阅方便。另外我们开了一个免费的讲解web前端课程,有兴趣的朋友可以去看,详情地址:
http://fe.qietu.com/forum.php

1、创建数组;

var arr = new Array(); //创建一个空数组;

var arr1 = new Array(3); //创建一个包含3项的数组,每一项都是undefined;

var arr2 = new Array("3"); //创建一个数组,只有一项为字符串3;

2、常用方法

join();

此方法可以把数组转换为字符串,接受一个参数指定数组每一项的连接符;若不加参数,默认为逗号;

例如:

var arr=[2,3,4];

arr.join(''); // "234"

arr.join('+'); // "2+3+4"

split();

此方法可以字符串转为数组;

例如:

var str="https://www.baidu.com/s?wd=javascript&rsv_spt=1&rsv_iqid=0xb5b5ce2900000036&issp=1&f=3&rsv_bp=0&rsv_idx=2&ie=utf-8&tn=baiduhome_pg";

str.split('?')[1].split('&');

//["wd=javascript", "rsv_spt=1", "rsv_iqid=0xb5b5ce2900000036", "issp=1", "f=3", "rsv_bp=0", "rsv_idx=2", "ie=utf-8", "tn=baiduhome_pg"]

push();

把元素从后面添加到数组;可以接受任意参数,返回数组的长度;

例如:

var arr=[2,3];

arr.push('d'); // 3;

alert(arr); // [2,3,"d"];

pop();

从数组末尾删除最后一项,减少数组的长度;不加参数;返回删除项;

例如:

var arr=[1,2,3];

arr.pop(); // 3;

arr; // [1, 2];

unshift();

把元素从前面添加到数组;可以接受任意参数,返回数组的长度;

例如:

var arr=[1,2,3];

arr.unshift(0); // 4

arr; // [0, 1, 2, 3]

shift();

删除数组的第一项,减少数组的长度;不加参数;返回删除项;

例如:

var arr=[0,1,2,3];

arr.shift(); //0

arr; //[1, 2, 3]

reverser();

反转数组的顺序;不够灵活更多时使用sort()方法;

例如:

var arr=[2,3,4,5]; arr.reverse();

[5, 4, 3, 2]

sort();

对数组进行排序,默认为升序(由小到大);可接受比较函数作为参数来指定如何排列;

例如:

var a=[6,4,8,1,0,9,4,2];

a.sort(function(a,b){return a-b}); // [0, 1, 2, 4, 4, 6, 8, 9]

a.sort(function(a,b){return b-a}); // [9, 8, 6, 4, 4, 2, 1, 0]

concat();

创建并返回一个新的数组;不改变原有数组;

例如:

var a=[2,3,4];

a.concat(["a","b"]); // [2, 3, 4, "a", "b"]

slice();

截取当前数组创建并返回一个新的数组;一到两个参数,分别代表起始位置和结束位置之间的项,不包含结束位置的项,当只有第一个参数,代表从参数指定位置到结尾;

例如:

var arr=[3,2,"a","c",6,"e"];

arr.slice(1,4); // [2, "a", "c"]

arr; // [3, 2, "a", "c", 6, "e"]

arr.slice(4); // [6, "e"]

splice();

功能强大;可实现插入、替换、删除方法;参数有多个;会修改原数组;

删除:可删除任意项,指定两个参数,分别代表 要删除第一项的位置和删除的项数。返回删除项

例如:

var arr=[3, 2, "a", "c", 6, "e"];

arr.splice(1,2); // [2, "a"]

arr; // [3, "c", 6, "e"]

替换:在任意位置插入任意数量的项,同时删除任意数量的项,第一个参数为起始位置,第二个参数为要删除的项数,后面分别代表要插入的每一项。删除的项数和插入的项数可以不相等。

例如:

var arr=[3, 2, "a", "c", 6, "e"];

arr.splice(2,1,"insert0","insert1");

arr; // [3, 2, "insert0", "insert1", "c", 6, "e"]

插入:在指定位置插入任意数量的项;第一个参数代表起始位置,第二个参数代表要插入的项0;如果是多个项,分别是为后面的参数

例如:

var a=[2,3,4];

a.splice(1,0,"insert0","insert1");

a; // [2, "insert0", "insert1", 3, 4]

ECMAScript 5 新方法:

注意兼容性问题,支持 chrome , IE9+ , FF2+ , Safari3+ , Opera9.5+

map();

迭代数组;对每一项运行对应的函数,参数可选值:数组项的值,该项在数组中的位置,数组对象本身 ;不会修改原数组;返回函数调用的结果组成的数组;

var arr=[1,4,3];

arr.map(function( res , n ){ return res+1 }); // [2, 5, 4]

forEach();

同map() 方法,迭代数组;对每一项运行对应的函数,无返回值;

更多迭代方法如 filter(),every(),some() 可参考其它教程

文/丁向明

做一个有博客的web前端自媒体人,专注web前端开发,关注用户体验,加我qq/微信交流:6135833

http://dingxiangming.com

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个else解...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。今天分享一下break和continue在代码中的执行效果是什么,进一步区分出二者的区别。一、continue例1:当小明3岁时不打印年龄,其余年龄正常循环打印。可以看...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。答案:CSS的盒模型是用于布局和定位元素的概念。它由内容区域...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录由浅入深,66条JavaScript面试知识点(一)由浅入深,66...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)1.vue的生命周期有哪些及每个生命周期做了什么?beforeCreate是newVue()之后触发的第一个钩子,在当前阶段data、methods、com...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...