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

js数组常用方法总结_js数组菜鸟教程

itomcoil 2025-02-21 13:40 15 浏览

首先说明,本文没技术含量,都是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

相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...