7.js数组常用方法剖析

js数组常用方法剖析

数组也是对象数据类型的,也是由键值对组成的

var ary = [12,23,34];
/*
 * 结构:
 *  0:12
 *  1:23
 *  2:34
 *  length:3 
 */
1. 以数组作为索引(属性名),索引从零开始递增
2. 有一个LENGTH属性存储的是数组长度
​
ary[0] 获取第一项
ary[ary.length-1] 获取最后一项

数组中每一项的值可以是任何数据类型的

//=>多维数组
var ary = [
    {
      name:'xxx',
      age:20
    },
    {
      name:'xxx',
      age:20
    }
];

1.1数组中的常用方法

按照四个维度记忆:

  • 方法的作用

  • 方法的参数

  • 方法的返回值

  • 原有数组是否改变

push 

作用:向数组“末尾”追加新的内容

参数:追加的内容(可以是一个,也可是多个)

返回值:新增后数组的长度

原有数组改变

var ary = [12,23,34];
ary.push(100); //=>4  ary:[12,23,34,100]
ary.push(100,{name:'xxx'}); //=>6  ary:[12,23,34,100,100,{...}]

pop

作用:删除数组最后一项

参数:无

返回:被删除的那一项内容

原有数组改变

shift

作用:删除数组中的第一项

参数:无

返回:被删除的那一项内容

原有数组改变

unshift

作用:向数组开始位置追加新内容

参数:要新增的内容

返回:新增后数组的长度

原有数组改变

splice

基于 SPLICE可以对数组进行很多的操作:删除指定位置的内容、向数组指定位置增加内容、还可以修改指定位置的信息

删除:ary.splice(n,m)

从索引n开始,删除m个内容,把删除的部分以一个新数组返回,原有数组改变

新增:ary.splice(n,0,x,...)

从索引n开始删除零项(没删除),把X或者更多需要插入的内容存放到数组中索引N的“前面”

修改:ary.splice(n,m,x,...)

修改的原理就是把原有内容删除掉,然后用新的内容替换这部分信息即可

需求扩展:

  1. 删除数组最后一项,你有几种办法?

  2. 向数组末尾追加新内容,你有几种办法?

//=>删除最后一项
ary.pop()
ary.splice(ary.length-1)
ary.length--
​
//=>向数组末尾追加新内容
ary.push(100)
ary.splice(ary.length,0,100)
ary[ary.length]=100

 

 

 

slice

作用:在一个数组中,按照条件查找出其中的部分内容

参数:两个参数(n/m),从索引n开始,找到索引m处,但是不包含m

返回:以一个新数组存储查找的内容

原有数组不会变

concat

作用:实现多个数组(或者值)的拼接

参数:数组或者值

返回:拼接后的新数组

原有数组不变

toString

作用:把数组转换为字符串

参数:无

返回:数组中的每一项用逗号分隔的字符串

原有数组不变

 

join

作用:和toString类似,也是把数组转换为字符串,但是我们可以设置变为字符串后,每一项之间的连接符

参数:指定的链接符

返回:字符串

原有数组不变

reverse

作用:把数组倒过来排列

参数:无

返回:排列后的新数组

原有数组改变

sort

作用:给数组排序

参数:无/函数

返回:排序后的新数组

原有数组改变

//=>sort在不传递参数的情况下,只能处理10以内数字排序
var ary=[1,3,2,4,5,6,7,9,8];
ary.sort(); =>[1,2,3,4,5,6,7,8,9]
​
var ary=[18,1,23,27,2,35,3,56];
ary.sort(); =>[1, 18, 2, 23, 27, 3, 35, 56] 没有按照我们想象中的排序
​
//=>真实项目中,基于sort排序,我们都需要传递参数
var ary=[18,1,23,27,2,35,3,56];
ary.sort(function (a,b){
    return a-b;//=>升序  return b-a; 降序
});

indexOf / lastIndexOf

这两个方法不兼容IE低版本浏览器(IE6~8)

作用:检测当前值在数组中第一次或者最后一次出现位置的索引

参数:要检测的值

返回:索引

原有数组不变

//=>验证数组中是否包含某一项
if(ary.indexOf(100)>-1){
   //=>ARY中包含100这一项
}

除了以上方法,数组中还包含很多常用的方法(Array.prototype)

  • every

  • filter

  • find

  • forEach

  • includes

  • keys

  • map

  • reduce / reduceRight

  • some

  • ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
旅游社交小程序功能有管理员和用户。管理员有个人中心,用户管理,每日签到管理,景点推荐管理,景点分类管理,防疫查询管理,美食推荐管理,酒店推荐管理,周边推荐管理,分享圈管理,我的收藏管理,系统管理。用户可以在微信小程序上注册登录,进行每日签到,防疫查询,可以在分享圈里面进行分享自己想要分享的内容,查看和收藏景点以及美食的推荐等操作。因而具有一定的实用性。 本站后台采用Java的SSM框架进行后台管理开发,可以在浏览器上登录进行后台数据方面的管理,MySQL作为本地数据库,微信小程序用到了微信开发者工具,充分保证系统的稳定性。系统具有界面清晰、操作简单,功能齐全的特点,使得旅游社交小程序管理工作系统化、规范化。 管理员可以管理用户信息,可以对用户信息添加修改删除。管理员可以对景点推荐信息进行添加修改删除操作。管理员可以对分享圈信息进行添加,修改,删除操作。管理员可以对美食推荐信息进行添加,修改,删除操作。管理员可以对酒店推荐信息进行添加,修改,删除操作。管理员可以对周边推荐信息进行添加,修改,删除操作。 小程序用户是需要注册才可以进行登录的,登录后在首页可以查看相关信息,并且下面导航可以点击到其他功能模块。在小程序里点击我的,会出现关于我的界面,在这里可以修改个人信息,以及可以点击其他功能模块。用户想要把一些信息分享到分享圈的时候,可以点击新增,然后输入自己想要分享的信息就可以进行分享圈的操作。用户可以在景点推荐里面进行收藏和评论等操作。用户可以在美食推荐模块搜索和查看美食推荐的相关信息。
JavaScript数组遍历有多种常用方法,例如for循环、forEach方法、map方法、reduce方法等。我们可以通过性能分析对比它们的效率。 首先是for循环,它是最基本的遍历方式。通过使用索引来访问数组元素,可以在遍历过程中直接对元素进行操作。这种方法是最快的,因为它没有额外的函数调用开销,并且可以灵活地控制遍历过程。 其次是forEach方法,它是ES5中引入的数组方法之一。它提供了一种简洁易懂的遍历方式,可以通过回调函数来处理每个元素。然而,forEach方法不能中途跳出循环,也不能直接修改原数组的值。因此,如果需要在循环中进行复杂的操作,它可能会导致一些性能上的损失。 再次是map方法,它也是ES5中的数组方法之一。它可以通过回调函数对数组中的每个元素进行操作,并将结果存储在一个新的数组中返回。map方法会创建一个新的数组,因此在性能方面相对较低。如果只需要遍历数组而不需要返回新的数组,推荐使用forEach方法,它更高效。 最后是reduce方法,它也是ES5中的数组方法之一。它可以通过回调函数对数组中的每个元素进行累积操作,最终返回一个累积值。reduce方法是一种非常灵活且强大的遍历方式,但相对而言性能相对较低。如果只需要遍历数组而不需要累积值,使用forEach方法会更高效。 综上所述,for循环是性能最高的遍历方式,但不如其他方法简洁易懂。根据实际需求来选择合适的遍历方法,可以在性能和代码可读性之间找到平衡点。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值