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.标识符命名最好是第一个字母小写,剩 ...
随机推荐
- (转) CS0234: 命名空间“System.Web.Mvc”中不存在类型或命名空间名称“Ajax”(是否缺少程序集引用?)
从SVN上down下来的程序,编译报了一大堆的错,发现是缺少引用,但是明明引用了,后来打开引用,发现system.web.mvc这个引用打着叹号,如图, 后来重新引用了本机的system.web.mv ...
- (转)VS无法启动调试:“生成下面的模块时,启用了优化或没有调试信息“
中调试项目遇到错误提示,Visual Studio 2010(或VS2008或VS2005)启动调试的时候,弹出提示信息: 生成下面的模块时,启用了优化或没有调试信息: C:\WINDOWS\Micr ...
- Ubuntu 添加sudo用户
第一种方法: 添加sudo用户 当你安装Ubuntu的时候,它会自动添加第一个用户到sudo组,允许这个用户通过键入其自身帐户密 码来获得超级用户(root)身份.然而,系统不会再自动添加其他的用户到 ...
- zookeeper端口号冲突:8080冲突
端口号冲突,在conf/zoo2181.cfg文件里面添加一个端口号的指定(具体的端口号可以自己定义一个): admin.serverPort=8081
- jQuery选择器全解
本篇介绍jQuery的选择器,jQuery选择器按照功能上分为"选择"和"过滤",并且是配合使用的.过滤的主要作用是从前面选定的选择器中选择的内容重进行筛选. ...
- C#time 闹钟
private void timer2_Tick(object sender, EventArgs e) { lbltime.Text = DateTime.Now.ToString(); & ...
- 2016/01/10 C++ Primer 小记 —— 命令行编译环境配置
OK!第一篇博文!自贺一下! 今日看了此书的前几页.嗯,说得挺全,基础易懂. 之前学过c++,但没用过命令行编译. 本人用的VS里的编译器,文件名是cl.exe,在VC目录下. 虽然有了编译器,但并不 ...
- runtime error ?
程序运行时错误(运行时出错就是出现在程序运行过程中的),有很多种: 比如:溢出.内存泄露.死循.乱用指针.数组越界(数组开小了?).除以0错误.递归太深层(系统暴栈了)
- android studio gradle自动签名构建实现
我为自己代言: 一.在android studio中生成签名文件. 1.在android studio 选中项目,在菜单栏中选择Build. 2.点击Generate Signed APK选项卡. 3 ...
- cf C. Find Maximum
http://codeforces.com/contest/353/problem/C 先预处理前i个数的和,然后找到第一个出现的1,然后变成0后的和与目前的和比较,如果大就更新. #include ...