Array类型

  Array也是ECMAScript中常用类型之一,其特点是数组中的每一项都可以保存任何类型的数据,数组的大小可以动态调整。

创建数组

方式1:使用`Array`构造函数

var books = new Array();
var books = new Array(20); //如果知道数组的大小,可以给构造函数传递该参数
var books = new Array("English", "math"); //创建包含三个字符串的数组
var books = Array(); //new关键字可以省略

方法2:使用数组字面量表示法

var books = ["englisg", "math"];
var names = [];
var tasks = [,,,,]; //不推荐用法,会根据浏览器的不同,创建4或者5项的数组

设置和读取数组

var colors = ["blue", "yellow", "red"];
alert(colors[0]); //使用方括号并提供基于相应值的基于0的数字索引
colors[3] = "black"; //可以替换指定位置的值;如果索引超过了数组现有的项数,只超出一项,则数组的索引值自动加1;像本利中如果colors[4]="green",那colors[3]会被自动存入undefined

  length属性

  length始终返回0或者更大的值,且它不是只读的,通过该属性可以从数组的末尾移除项或向数组中添加添加新项:

var books = ["English", "math"];
books.length = 1;
console.log(books[1]); //undefined var books = ["English", "math"];
books.length = 2;
console.log(books[2]); //undefined //数组的最后一项的索引始终是length-1,因此下一个新项目的位置就是length,用来添加项目非常方便
var books = ["English"];
books[books.lenth] = "math";

检测数组

if(Array.isArray(value)) {
//对数组执行某些操作
}

转换方法

var books = ["English", "math"];
console.log(books.toString()); //English,math
console.log(books.valueOf());//["English", "math"]
console.log(books);//["English", "math"]

  数组继承的toLocaleString()toString()valueOf()方法,在默认情况下都会以逗号分割的字符串的形式返回数组项。如果使用join()方法,则可以使用不同的分隔符来构建这个字符串。

//join()方法接收一个参数,即分隔符
var books = ["English", "math"];
console.log(books.join(",")); //English,math
console.log(books.join("||")); //English||math

栈方法

  `push()`方法接收任意数量的参数,把它们逐个添加到数组的末尾,并返回修改后数组的长度

var books = new Array();
var count = books.push("English", "math");
console.log(count); //2
count = books.push("Chinese");
console.log(count); //3

  pop()方法则从数组末尾移除最后一项,减少数组的length值,然后返回移除的项

var item = books.pop();
console.log(item); //Chinese
console.log(books.length); //2

队列方法

  `shift()`能够移除数组中的第一个项并返回该项,同时数组长度减1

var books = new Array();
var count = books.push("English", "math");
console.log(count); //2
count = books.push("Chinese");
console.log(count); //3
var item = books.shift();
console.log(item); //English
console.log(books.length); //2

  unshift()能在数组前端添加任意个项并返回新数组的长度

var books = new Array();
var count = books.unshift("English", "math");
console.log(count); //2
count = books.unshift("black");
console.log(count); //3 var item = books.pop();
console.log(item); //math
console.log(books.length); //2

重排序方法

  `reverse()`翻转数组项的顺序

var num = [1, 4, 3, 5, 2];
num.reverse();
console.log(num); //[2, 5, 3, 4, 1]

  sort()按照升序排列数组项,该方法会调用每个数组项的toString()转型方法,然后比较得到的字符串,然后这种方法并不是最佳的,即使数组中每一项都是数值,但是最后比较的都是字符串,因此sort()方法可以接受一个比较函数座位参数,方便指定哪个值位于哪个值的前面。

function compare(val1, val2) {
if(val1 < val2){
return 1;
} else if(val1 > val2){
return -1;
} else {
return 0;
}
} var num = [0, 1, 4, 10, 12];
num.sort(compare);
console.log(num); //[12, 10, 4, 1, 0]

操作方法

  `concat()`方法可以基于当前数组中的所有项创建一个新数组

var books = ["English", "math"];
//传递给concat()方法的是一或多个数组,则该方法会将这些数组中的每一项都添加到结果数组中
var books2 = books.concat("PE", ["Chinese", "Chemistry"]);
console.log(books); //["English", "math"]
console.log(books2); //["English", "math", "PE", "Chinese", "Chemistry"]

  slice()方法能够基于当前数组中的一个或者多个项创建一个新数组

var books = ["English", "math", "Computer"];
var books2 = books.slice(1); //表示从1位置开始截取
var books3 = books.slice(1, 2); //表示从1位置开始截取,到位置2结束
console.log("books2"); // ["math", "Computer"]
console.log("books3"); // ["math"]

  splice()方法

  1. 删除 指定两个参数, 要删除的第一项的位置和要删除的项数

  2. 插入 指定三个参数,起始位置、0(要删除的项数),要插入的项

  3. 替换 指定三个参数, 起始位置,要删除的项数和要插入的任意数量的项

    //删除第一项

    var books = ["English", "math", "Chinese"];

    var removed = books.splice(0, 1);

    console.log(books); //["math", "Chinese"]

    console.log(removed); // ["English"]

    //从位置1开始插入两项

    removed = books.splice(1, 0, "PE", "Chemistry");

    console.log(books); // ["math", "PE", "Chemistry", "Chinese"]

    console.log(removed); // []

    //插入两项,删除一项

    removed = books.splice(1, 0, "English", "Biology");

    console.log(books); //["math", "English", "Biology", "PE", "Chemistry", "Chinese"]

    console.log(removed); // []

位置方法

  `indexOf()`从数组的开头(位置0)开始向后查找,返回要查找的项在数组中的位置,没找到返回-1

  `lastIndexOf()`从数组的末尾开始向前查找

var num = [1, 2, 4, 7];
console.log(num.indexOf(2)); //1

迭代方法

  一共5个迭代方法,每个方法都接收两个参数:在每一项商誉性的函数和运行在该函数的作用域的对象--影响this的值。传入这些方法中的函数会接收三个参数,数组项的值、该项在数组中的位置和数组对象本身

//对数组中每一项都运行指定函数,如果这个函数对每一项的结果都是true,就返回true
var num = [1, 2, 4, 5, 6];
var everyResult = num.every(function(item, index, array){
return(tiem >2 );
})
console.log(everyResult); //false //对数组中的每一项都运行指定函数,如果这个函数对任一项的结果返回true,就返回true
var someResult = num.some(function(item, index, array){
return (item >2);
})
console.log(someResult); //true //filter()方法,有了前面两个例子,顾名思义该方法是对数组中的项用指定的函数来进行过滤,将过滤得到的项组成数组返回
var num = [1, 2, 4];
var filterResult = num.filter(function(item, index, array){
return (item > 2);
})
console.log(filterResult); //[4] //map()方法也返回一个数组,是针对原有数组的每一项运行传入函数的结果,所组成的新的数组
var num = [1, 2, 3];
var mapResult = num.map(function(item, index, Array){
return item*2;
})
console.log(mapResult);//[2, 4, 6] //forEach()对数组中的每一项进行迭代,该方法没有返回值
var num = [1, 2, 3];
num.forEach(function(item, index, Array){
//执行操作
})

归并方法

  `reduce()`和`reduceRight()`

Array类型的更多相关文章

  1. JS高程5.引用类型(2)Array类型

    Array类型: ECMAScript数组的每一项可以保存任何类型的数据,数组的大小是可以动态调整的. 创建数组的基本方式: (1)使用Array构造函数 var color=new Array(); ...

  2. 5.2 Array类型介绍

    Array类型是数组类型,Array(数组)类型也是引用类型中的一种. js 数组中的每一项可以保存任何类型的数据. js数组的大小/长度是可以动态调整的.如果你往数组中添加数据,数组长度会自动增加. ...

  3. JavaScript中Array类型方法总结

    Array类型是ECMAScript中最常用的类型之一,ECMAScript中的数组与其他多数语言中的数组有着相当大的区别.ECMAScript数组的每一项可以保存任何类型的数据.这里总结了数组类型的 ...

  4. Object类型与Array类型

    总结--JS中的引用类型: Object类型,Array类型,Boolean类型,Number类型,String类型,Date类型, Function类型,RegExp类型,单体内置对象(Global ...

  5. oracle Array类型作为参数传入函数(存储过程) 大字符串参数解决方案

    1. 创建自定义的类型.由于Oracle没有提供现成的array类型,这里用table类型来模拟. CREATE OR REPLACE TYPE varchar_array is Table OF v ...

  6. mongo中查询Array类型的字段中元素个数

    I have a MongoDB collection with documents in the following format: { "_id" : ObjectId(&qu ...

  7. 引用类型之Array类型

    Array类型 ECMAScript数组与其它语言数组一样,都是数据的有序列表.但是ECMAScript数组的每一项可以保存任何类型的数据.而且,ECMAScript数组是可以动态调整的. 1.创建和 ...

  8. JavaScript引用类型之Array类型一

    一.简介 除了Object之外,Array类型恐怕是ECMAScript中最常用的类型了.下面就来分析ECMAScript中的数组与其他语言中的数组的异同性: 1.相同点: (1)他们都是数据的有序列 ...

  9. 如何判断一个变量是数组Array类型

    在很多时候,我们都需要对一个变量进行数组类型的判断.JavaScript中如何判断一个变量是数组Array类型呢?我最近研究了一下,并分享给大家,希望能对大家有所帮助. JavaScript中检测对象 ...

  10. 从头开始学JavaScript (十二)——Array类型

    原文:从头开始学JavaScript (十二)--Array类型 一.数组的创建 注:ECMAscript数组的每一项都可以保存任何类型的数据 1.1Array构造函数 var colors = ne ...

随机推荐

  1. android-zip解压缩方法

    /** * 解压缩文件到指定的目录. * * @param unZipfileName * 需要解压缩的文件(带路径) * @param mDestPath * 解压缩后存放的路径 **/ publi ...

  2. 《Mysql技术内幕,Innodb存储引擎》——索引与算法

    B+树 B+树中,所有记录节点都按照键值的大小顺序放在同一层叶子节点,各个叶子节点指针进行连接. 图中指针是单向的,但是书上的图是双向的,而且旋转应该也是双向才能完成) B+树插入处理 Leaf Pa ...

  3. 机器学习--降维算法:PCA主成分分析

    引言 当面对的数据被抽象为一组向量,那么有必要研究一些向量的数学性质.而这些数学性质将成为PCA的理论基础. 理论描述 向量运算即:内积.首先,定义两个维数相同的向量的内积为: (a1,a2,⋯,an ...

  4. Mahout实战---编写自己的相似度计算方法

    Mahout本身提供了很多的相似度计算方法,如PCC,COS等.但是当需要验证自己想出来的相似度计算公式是否是好的,这时候需要自己实现相似度类.研究了Mahout-core-0.9.jar的源码后,自 ...

  5. HDFS:分布式文件系统

    HDFS是GFS的简化版,它同一时刻只允许一个用户对同一文件进行追加写操作(GFS允许并发写).它适合存储大文件,并提供高吞吐量的顺序读/写访问. 它的早期版本两大问题,例如:单点失效和水平扩展不佳. ...

  6. Beta阶段——Scrum 冲刺博客第五天

    一.当天站立式会议照片一张 二.每个人的工作 (有work item 的ID),并将其记录在码云项目管理中 昨天已完成的工作 完成部分answer界面的制作,将题目与用户输入的答案.正确答案依次列出来 ...

  7. Beta--冲刺阶段合集

    冲刺前计划与安排:https://www.cnblogs.com/pubg722/p/9069234.html 第一篇冲刺博客:http://www.cnblogs.com/pubg722/p/909 ...

  8. linux的文件基本属性

    Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限.为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定 1.在Linux中我们 ...

  9. log4j.properties配置模板

    # For JBoss: Avoid to setup Log4J outside $JBOSS_HOME/server/default/deploy/log4j.xml! # For all oth ...

  10. java设计模式-----18、职责链模式

    概念: Chain of Responsibility(CoR)模式也叫职责链模式.责任链模式或者职责连锁模式,是行为模式之一,该模式构造一系列分别担当不同的职责的类的对象来共同完成一个任务,这些类的 ...