JS高级程序设计学习笔记之数组
- 数组创建的方式
- var str = new Array();放入数字即为设置数组长度
- var str = [];
- 数组的length可读可写
- 监测数组
- Array.isArray()方法确定某个值是不是数组,兼容的浏览器为IE9+、ff4+、sf5+、O10.5+、chrome
- 转换方法
- toString()方法会返回由数组中每个值的字符串形式拼接而成的一个以逗号分割的字符串。
- value Of()方法返回数组。(alert要接收字符串参数,当传给它数组时,会在后台调用toString()方法)
- toLocaleString()创建一个数组值的以逗号分隔的字符串。对每一项调用toLocalString()方法。
- join(),接收一个参数用接收的字符串做分隔符,分割数组为一个字符串,并返回这个字符串。
- 若数组中某一项为null或者undefined,那么该值在以上方法返回的结果中以空字符串表示。
- 栈方法(后进先出)
- push()方法接收任意参数,并将其逐个添加到数组末尾,并返回修改后的数组长度。
- pop()方法从数组末尾移除最后一项,减少length值,返回移除的项。
- 队列方法(先进先出)
- shift()方法,移除数组中的第一项并返回该项,长度减一。
- push()
- unshift(),在数组前端添加任意个项,并返回新的数组长度。
- 重排序方法
- reverse()方法,反转数组顺序。var value =[1,2,3,4];value.reverse();
- sort(),以升序排列数组。sort()方法调用每个数组项的toString()方法,然后比较得到的字符串。Sort()方法接受一个比较函数作为参数,若参数一应位于参数二之前,则返回负数。以此类推
- 操作方法
- concat()方法,复制当前数组,将参数添加到末尾,返回新的数组。
- slice()方法:①只有一个参数时,该方法返回从该参数指定位置到数组末尾的所有项。
②有两个参数时,返回起始位置与结束位置的项,不包括结束的项。该方法不影响原数组。
③若参数中存在负数,用数组长度加上负数决定位置。若起始位置大于结束位置,则返回空数组。
- splice()方法:①删除:参数一:要删除的第一项的位置。参数二:要删除的项数。
②插入:参数一:起始位置。参数二:要删除的项数(0)。参数三:要插入的项(可以插入多各项,作为更多的参数)
③替换:参数一:起始位置。参数二:要删除的项数(0)。参数三:要插入的项(可以插入多各项,作为更多的参数)
该方法始终返回一个数组,数组包含从原始数组中删除的项,若未删除,则为空数组。
- 位置方法:
- indexOf():参数一:要查找的项。参数二:查找的起点位置(要求查找的项必须严格相等)。从头查找
- lastIndexOf():参数一:要查找的项。参数二:查找的起点位置(要求查找的项必须严格相等)。从末尾查找
- 迭代方法:参数一:要在每一项上运行的函数(该函数有三个参数(数组项的值,该项在数组中的位置,数组本身))
参数二:运行该函数的作用域对象(可选)
①every()方法,对数组的每一项运行该函数,若函数对每一项都返回true,则方法返回true。
②filter()方法,对数组的每一项运行该函数,将返回true的每一项组成数组并返回。
③forEach()方法,对数组每一项运行该函数,无返回值。
④map()方法,对数组的每一项运行该函数,返回每次函数调用的结果组成的数组。
⑤some()方法,对数组的每一项运行该函数,若函数对任一项返回true,6则返回true。
- 归并方法:迭代数组所有的项,然后构建一个最终返回的值。
接收两个参数(每一项上调用的函数(前一个值,当前值,项的索引,数组),作为归并基础的初始值(可选))。这个函数返回的任何值都会作为第一个参数自动传给下一项。
reduce()从头迭代。
reduceRight()从尾迭代
高程3—P97页
JS高级程序设计学习笔记之数组的更多相关文章
- JS高级程序设计学习笔记之第三章基本概念(语法,数据类型,流控制语句,函数)——查漏补缺
一.语法: 区分大小写; 2.标识符:就是指变量.函数.属性的名字,或者函数的参数 a.标志符的规则:①第一个字符必须是一个字母.下划线(_)或一个美元符号($). ...
- JS高级程序设计学习笔记1
javascript产生的原因: 在拨号上网时代,表单数据必须发送到服务器端才能验证输入值得有效性,JavaScript的研发就是为了解决这个问题,以便在客户端就验证输入值的有效性. ECMAScri ...
- JS高级程序设计学习笔记之RegExp类型
创建正则表达式: 字面量形式定义正则表达式: Var expression = / pattern /flags ;pattern部分可以使任意简单或复杂的正则表达式.每个正则表达式可以带有一个或多个 ...
- JS高级程序设计学习笔记——继承
我们知道,在OO语言中,继承可分为接口继承和实现继承.而ECMAScript的函数没有签名,不能实现“接口继承”,只能通过原型链实现“实现继承”. 在学习了各种继承模式之后,简单总结一下各种继承模式的 ...
- JS高级程序设计学习笔记之基本包装类型
概述 基本类型:string.boolean.number 每当读取一个基本类型的值的时候,后台就会创建一个对应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据. 使用new操作符创建的 ...
- JS高级程序设计学习笔记之Date类型
日期对象的创建:var now =new Date(),不传递参数时,对象自动获取当前时间.(若要创建特定日期与时间的对象,必须传入该日期距离1970/1/1零点的毫秒数). Date.parse() ...
- JS高级程序设计学习笔记之JS事件(1)
事件流 冒泡 定义:事件开始时由最具体的元素接收,然后逐级上传到较为不具体的节点.(IE9.FF.Chrome.Safari会将事件一直冒泡到window对象.IE5.5及其以下会跳过<html ...
- 《JS高级程序设计》笔记 —— 解析查询字符串
今天在继续翻阅<JS高级程序设计>的时候,正好翻到location对象这一小节,其中有一部分就是讲的解析查询字符串.看到这个内容立马想到了做去哪儿秋招笔试题的时候有这么一道题. 去哪儿笔试 ...
- JavaScript高级程序设计---学习笔记(一)
今天,2017.3.17开始利用课余时间仔细学习<JavaScript高级程序设计>,将需要掌握的知识点记录下来,争取把书里的所有代码敲一遍并掌握. 1.标识符命名最好是第一个字母小写,剩 ...
随机推荐
- C#中通过类来继承两个接口,父类实例化接口中的方法,子类继承父类,调用方法
实现了父类继承接口,父类实例化接口的方法,子类继承父类,子类调用父类的方法直接使用 代码如下: using System; using System.Collections.Generic; usin ...
- border和outline区别
border和outline区别: border支持box-sizing: border-box,当有边距时,是新增了边框后在按照以前的边距处理 outline不支持box-sizing: borde ...
- ArcEngine - 栅格数据访问的-对象模型
- AVL树相关操作
#include <iostream> using namespace std; //AVL树的节点 template<typename T> class TreeNode { ...
- xode 中文乱码处理
find *.* -exec sh -c "iconv -f GB18030 -t UTF-8 {} > {}.txt" \;
- php开发客服系统(持久连接+轮询+反向ajax)
欢迎在php严程序 - php教程学习AJAX教程, 本节课讲解:php开发客服系统(持久连接+轮询+反向ajax) php开发客服系统(下载源码) 用户端(可直接给客户发送消息)客服端(点击用户名. ...
- mysql日志文件相关的配置【2】
1.二进制日志是什么? mysql 的二进制日志用于记录数据库上做的变更. 2.二进制日志什么时间写到磁盘 1.总的来说二进制日志会在释放锁之前就写入磁盘.也就是说在commit完成之前:client ...
- commons-pool2-中的一些配置
/** * 连接失效检测相关 */ // 空闲时进行连接测试,会启动异步evi ...
- MySql 学习笔记 (派生表)
派生表也是一种子查询那么它出现在 select * from ( select * from b <--这个就是派生表啦 )派生表其实不是个好东西,在生产的时候他是可以通过索引来过滤的,但是一但 ...
- 对拍 For Linux
#!/bin/sh g++ -g gene.cpp -o gene g++ -g a.cpp -o a g++ -g b.cpp -o b while true; do ./gene > in ...