Array方法归类总结
数组的转换方法
valueOf()方法,数组调用该方法后返回的还是原来的数组。
toString()方法,数组调用该方法后会调用每一项的toStirng()方法,之后将每一项拼接成一个以逗号分割的字符串。
toLocaleString()方法,把数组转换为本地字符串,这个方法与toString()方法的作用相同,大多数时候返回的结果也相同。调用的是每一项的toLocaleString()方法。
join()方法,同样是将数组转换为字符串,不穿参数或者参数为undefined的情况下,等同于toString()方法。传递参数将以特定的字符分隔。
数组的检测方法
instanceof构造函数,确定一个对象是否由相应的构造函数创建或者原型链继承自某个构造函数。
Array.isArray()方法,只为确定这个对象是否为数组。
Object.prototype.toString.call()方法,通过调用Object原型中的方法确定具体的对象类型。
数组的查找方法
indexOf()方法,查找数组的某一项,这里对比是否相等时,使用的是===(全等操作符),所以NaN不会与任何值相等,对象数组中的对象也要值和引用都相等。找到返回索引位置,未找到返回-1。
lastIndexOf()方法,和indexOf()方法相同,只不过前者从前向后,即查找第一次出现的位置,而后者从后向前,即查找最后一次出现的位置,两个方法可以接收第二个参数,为起始查找的位置。
数组的排序方法
reverse()方法,用于翻转数组。
sort()方法,排序数组,默认为字典序排序,在比较的时候比较的数组每个项的字符串所以对于排序后会出现不想要的结果。所以接收一个比较函数,这个比较函数接收两个参数,分别代表数组的项,如果第一个参数位于应该位于第二个参数之前返回一个负数,如果第一个参数应该在第二个参数之后返回一个正数,相等则返回0。
数组的栈方法(队列方法就是从后面添加从后面删除)
push()方法,用于向数组的末尾添加任意数量的新项,返回的是更新后数组的length值。
pop()方法,删除数组末尾的一项,返回的是删除的项,同时会更新数组的length值。
数组的队列方法(队列方法就是从后面添加从前面删除)
push()方法,用于实现从后面添加。
shift()方法,用于删除数组的第一项,返回的是删除的项,同时更新length值。
unshift()方法,与push()方法遥相呼应,unshift()方法用于项数组的前端添加任意的项数,返回更新后的length值。
数组的操作方法
concat()方法,接受数组或者其它数据类型,添加到数组的后端。
slice()方法,基于原始数组创建子数组,两个参数分别是,起始位置和结束位置(不包含),如果没有结束位置则到最后。
splice()方法,数组的万能方法,用于删除、添加、替换。
数组5个迭代方法
这五个方法都接两个参数,分别是一个函数和在那个作用域中运行影响this的值。这个函数可以接受三个参数,分别是数组的项、索引、数组本身。
every()方法,运行指定的函数,如果数组每一项都符合函数的执行条件则返回true。
some()方法,运行指定的函数,如果数组中有一项符合函数的执行条件则返回true。
filter()方法,运行指定的函数,返回符合函数执行条件后的数组。
map()方法,运行指定的函数,返回对每一项执行函数后结果的数组。
forEach()方法,与map()方法类似,没有返回值。
两个归并方法
这两个方法都接收两个参数,分别是一个函数和运行递归的初始值。这个函数接收四个参数,初始值(累加项)、当前值,索引和函数本身。
reduce()方法,从第一项开始。
reduce()方法,从最后一项开始。
以上这些方法能够改变原数组的有
reverse(),sort()
push(),pop()
unshift(),shift()
slice(),splice()
以上这些方法不能改变原数组的有
valueOf(),toString(),join(),toLocaleString()
indexOf(),lastIdexOf()
concat()
some(),every(),filter(),map(),forEach()
reduce(),reduceRight()
更详细的在:http://www.cnblogs.com/ghostff/articles/6397216.html
Array方法归类总结的更多相关文章
- js中Array方法归类解析
为什么要对Array方法进行归类解析 因为它常用,而且面试必问 改变原数组的方法 pop 删除并返回数组最后一个元素push 从末尾给数组添加元素,返回新数组length值reverse 颠倒数组元素 ...
- S5中新增的Array方法详细说明
ES5中新增的Array方法详细说明 by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wor ...
- ES5中新增的Array方法详细说明
一.前言-索引 ES5中新增的不少东西,了解之对我们写JavaScript会有不少帮助,比如数组这块,我们可能就不需要去有板有眼地for循环了. ES5中新增了写数组方法,如下: forEach (j ...
- 【原】javascript笔记之Array方法forEach&map&filter&some&every&reduce&reduceRight
做前端有多年了,看过不少技术文章,学了新的技术,但更新迭代快的大前端,庞大的知识库,很多学过就忘记了,特别在项目紧急的条件下,哪怕心中隐隐约约有学过一个方法,但会下意识的使用旧的方法去解决,多年前ES ...
- 5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例
ES5中,一共有9个Array方法 Array.prototype.indexOf Array.prototype.lastIndexOf Array.prototype.every Array.pr ...
- js Array 方法总结
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Javascript Array 方法整理
Javascript Array 方法整理 Javascript 数组相关方法 说明 大多数其它编程语言不允许改变数组大小,越界访问索引会报错,但是 javascript不会报错,不过不建议直接修改a ...
- ECMAScript5中新增的Array方法实例详解
ECMAScript5标准发布于2009年12月3日,它带来了一些新的,改善现有的Array数组操作的方法.(注意兼容性) 在ES5中,一共有9个Array方法:http://kangax.githu ...
- JavaScript中Array方法总览
title: JavaScript中Array方法总览 toc: true date: 2018-10-13 12:48:14 push(x) 将x添加到数组最后,可添加多个值,返回数组长度.改变原数 ...
随机推荐
- mongodb 3.x connect with credential
package mongoDb; import java.net.UnknownHostException; import java.util.ArrayList; import java.util. ...
- @synthesize和@dynamic
@synthesize 除非开发人员已经做了,否则由编译器自动生成getter/setter方法.当开发人员自定义存或取方法时,自定义会屏蔽自动生成该方法. @dynamic 告诉编译器,不自动生成g ...
- 【转】PHP生成随机密码的几种方法
使用PHP开发应用程序,尤其是网站程序,常常需要生成随机密码,如用户注册生成随机密码,用户重置密码也需要生成一个随机的密码.随机密码也就是一串固定长度的字符串,这里我收集整理了几种生成随机字符串的方法 ...
- 【转】HTTP响应报文与工作原理详解
超文本传输协议(Hypertext Transfer Protocol,简称HTTP)是应用层协议.HTTP 是一种请求/响应式的协议,即一个客户端与服务器建立连接后,向服务器发送一个请求;服务器接到 ...
- 每个Javascript开发者都应当知道的那些事
每个Javascript开发者都应当知道的那些事 2015-06-07 前端大全 (点击上方蓝字,可快速关注我们) Javascript是一种日益增长的语言,特别是现在ECMAScript规范按照每年 ...
- css 之!important
主要是自己犯了个错误: 把 !important 放到了分号后面; 正确写法写法: .current{ background-color: #f1f1f1; border-left: 2px soli ...
- cocoapod升级版本
原文 http://blog.csdn.net/sing_sing/article/details/49762359 该方法好用 sudo gem install -n /usr/local/bin ...
- 9.TCP:传输控制协议
1.TCP功能 TCP向应用层提供面向连接的.可靠的字节流服务.TCP可以认为是一个没有选择确认或否认的滑动窗口协议. TCP将用户数据打包构成报文段:它发送数据后启动一个定时器:另一 ...
- 在Delphi中隐藏程序进程
在开发某些软件的时候,为了保护程序自身,就需要用到隐藏程序进程.以下通过实例来讲解隐藏程序进程的方法: 1.创建一个新的项目 Project1 选择File,New Application.在表单Fo ...
- php如何判断是手机访问还是电脑访问
<?php function isMobile(){ $useragent=isset($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AG ...