判断对象是否为数组。
把数组的所有元素放入一个字符串。
返回数组的可迭代对象,包含原始数组的键(key)。
返回一个指定的字符串值最后出现的位置,在一个字符串中的指定位置从后向前搜索。
通过指定函数处理数组的每个元素,并返回处理后的数组。
删除数组的最后一个元素并返回删除的元素。
向数组的末尾添加一个或更多元素,并返回新的长度。
将数组元素计算为一个值(从左到右)。
将数组元素计算为一个值(从右到左)。
反转数组的元素顺序。
删除并返回数组的第一个元素。
选取数组的的一部分,并返回一个新数组。
检测数组元素中是否有元素符合指定条件。
对数组的元素进行排序。
从数组中添加或删除元素。
把数组转换为字符串,并返回结果。
向数组的开头添加一个或更多元素,并返回新的长度。
返回数组对象的原始值。
2.11 isArray()
定义和用法
isArray() 方法用于判断一个对象是否为数组。
如果对象是数组返回 true,否则返回 false。
语法
Array.isArray(obj)
2.12 join()
定义和用法
join() 方法用于把数组中的所有元素转换一个字符串。
元素是通过指定的分隔符进行分隔的。
语法
array.join(separator)
参数值
参数
描述
separator
可选。指定要使用的分隔符。如果省略该参数,则使用逗号作为分隔符。
返回值
类型
描述
String
返回一个字符串。该字符串是通过把 arrayObject 的每个元素转换为字符串,然后把这些字符串连接起来,在两个元素之间插入 separator 字符串而生成的。
实例
使用不同的分隔符:
var fruits = ["Banana", "Orange", "Apple", "Mango"];
var energy = fruits.join(" and ");结果:Banana and Orange and Apple and Mango
2.13 keys()
定义和用法
keys() 方法用于从数组创建一个包含数组键的可迭代对象。
如果对象是数组返回 true,否则返回 false。
语法
array.keys()
例
// simple array
var arr = ['a', 'b', 'c'];
console.log(Object.keys(arr)); // console: ['0', '1', '2']
// array like object
var obj = { 0: 'a', 1: 'b', 2: 'c' };
console.log(Object.keys(obj)); // console: ['0', '1', '2']
注意
在ES5里,如果此方法的参数不是对象(而是一个原始值),那么它会抛出 TypeError。
在ES2015中,非对象的参数将被强制转换为一个对象。
Object.keys("foo");
// TypeError: "foo" is not an object (ES5 code)
Object.keys("foo");
// ["0", "1", "2"] (ES2015 code)
2.14 lastIndexOf()
定义和用法
lastIndexOf() 方法可返回一个指定的元素在数组中最后出现的位置,在一个数组中的指定位置从后向前搜索。
如果要检索的元素没有出现,则该方法返回 -1。
该方法将从尾到头地检索数组中指定元素 item。开始检索的位置在数组的 start 处或数组的结尾(没有指定 start 参数时)。如果找到一个 item,则返回 item 从尾向前检索第一个次出现在数组的位置。数组的索引开始位置是从 0 开始的。
如果在数组中没找到指定元素则返回 -1。
提示: 如果你想查找数组首次出现的位置,请使用 indexOf() 方法。
语法
array.lastIndexOf(item,start)
实例
var fruits=["Banana","Orange","Apple","Mango","Banana","Orange","Apple"];
var a = fruits.lastIndexOf("Apple",4);结果: 2
2.15 map()
定义和用法
map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。
map() 方法按照原始数组元素顺序依次处理元素。
注意: map() 不会对空数组进行检测。
注意: map() 不会改变原始数组。
语法
array.map(function(currentValue,index,arr), thisValue)
实例
var numbers = [65, 44, 12, 4];
function multiplyArrayElement(num) {
return num * 10;
}
function myFunction() {
console.log(numbers.map(multiplyArrayElement));
}结果:新数组: 650,440,120,40
2.16 pop()
定义和用法
pop() 方法用于删除数组的最后一个元素并返回删除的元素。
注意:此方法改变数组的长度!
提示: 移除数组第一个元素,请使用 shift() 方法。
语法
array.pop()
例:
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.pop();
结果:
Banana,Orange,Apple
2.17 push()
定义和用法
push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。
注意: 新元素将添加在数组的末尾。
注意: 此方法改变数组的长度。
提示: 在数组起始位置添加元素请使用 unshift() 方法。
语法
array.push(item1, item2, ..., itemX)
例
var numbers = [65, 44, 12, 4];
function getSum(total, num) {
return total + num;
}
function myFunction(item) {
console.log(numbers.reduce(getSum));
}
结果:
125
2.18 reduce()
定义和用法
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。
reduce() 可以作为一个高阶函数,用于函数的 compose。
注意: reduce() 对于空数组是不会执行回调函数的。
语法
array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
参数
参数
描述
function(total,currentValue, index,arr)
必需。用于执行每个数组元素的函数。
函数参数:
参数
描述
total
必需。初始值, 或者计算结束后的返回值。
currentValue
必需。当前元素
currentIndex
可选。当前元素的索引
arr
可选。当前元素所属的数组对象。
initialValue
可选。传递给函数的初始值
2.19 reverse()
定义和用法
reverse() 方法用于颠倒数组中元素的顺序。
语法
array.reverse()
实例
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.reverse();
结果:
Mango,Apple,Orange,Banana
2.20 shift()
定义和用法
shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。
语法
array.shift()
实例
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.shift()
结果:
Orange,Apple,Mango
2.21 slice()
定义和用法
slice() 方法可从已有的数组中返回选定的元素。
slice()方法可提取字符串的某个部分,并以新的字符串返回被提取的部分。
注意: slice() 方法不会改变原始数组。
语法
array.slice(start, end)
参数 Values
参数
描述
start
可选。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end
可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。
返回值
Type
描述
Array
返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。
实例
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var myBest = fruits.slice(-3,-1); //倒数从 -1开始计起结果:Lemon,Apple
2.22 some()
定义和用法
some() 方法用于检测数组中的元素是否满足指定条件(函数提供)。
some() 方法会依次执行数组的每个元素:
- 如果有一个元素满足条件,则表达式返回_true_ , 剩余的元素不会再执行检测。
- 如果没有满足条件的元素,则返回false。
注意: some() 不会对空数组进行检测。
注意: some() 不会改变原始数组。
语法
array.some(function(currentValue,index,arr),thisValue)
例
var ages = [4, 12, 16, 20];
function checkAdult(age) {
return age >= 18;
}
function myFunction() {
console.log(ages.some(checkAdult));
}结果:true
2.23 splice()
定义和用法
splice() 方法用于添加或删除数组中的元素。
注意:这种方法会改变原始数组。
语法
array.splice(index,howmany,item1,.....,itemX)
参数 Values
参数
描述
index
必需。规定从何处添加/删除元素。
该参数是开始插入和(或)删除的数组元素的下标,必须是数字。
howmany
必需。规定应该删除多少元素。必须是数字,但可以是 "0"。
如果未规定此参数,则删除从 index 开始到原数组结尾的所有元素。
item1, ..., itemX
可选。要添加到数组的新元素
例
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.splice(2,1,"Lemon","Kiwi");结果Banana,Orange,Lemon,Kiwi,Mango
菜鸟写文章,不喜勿喷,如有错误,请指正。