标签:last 数组 foreach block sum 截取 排序 参数 ora
var colors = new Array();
var colors = [];
//检测数组 instanceof
// 1. if(value instanceof Array) {}
// 2. Array.isArray()
if(Array.isArray(value)) {
}
var colors = [‘red‘, ‘blue‘, ‘green‘];
// console.log(colors.toString()); //red,blue,green
// console.log(colors.valueOf()); // ["red", "blue", "green"]
console.log(colors.join(",")); //red,blue,green
console.log(colors.join()) //red,blue,green
console.log(colors.join("||")) //red||blue||green
队列数据结构是先进先出
push() pop()
// 栈方法 栈是一种后进先出的数据结构
// push() pop()
// push() 添加到数组末尾
// pop()从数组末尾移除最后一项
var colors = new Array();
var count = colors.push("red", "green");
count = colors.push(‘black‘);
console.log(count) //3
console.log(colors) //["red", "green", "black"]
var item = colors.pop();
console.log(colors) // ["red", "green"]
shift() unshift()
// 队列方法
// 队列数据结构是先进先出
// shift() unshift()
// shift() 移除数组中的第一个项并返回该项
// unshift() 向数组前端添加任意项并返回新数组的长度
var colors = new Array();
var count = colors.push("red", "green");
console.log(colors);
count = colors.push(‘black‘);
var item = colors.shift();
console.log(item)// red
console.log(colors)// ["green", "black"]
var colors = new Array();
var count = colors.unshift("red", "green");
console.log(count)//2
count = colors.unshift("black");
console.log(colors)// ["black", "red", "green"]
var item = colors.pop();
console.log(item) // green
console.log(colors) // ["black", "red"]
reverse() sort()
// reverse() sort()
// reverse()数组翻转
// sort() 方法按升序排列数组项
// sort()方法本质上实现是调用每个数组项的toString()转型方法,然后比较得到的字符串,来确定排序。即使数组的每项都是数组,sort()方法比较的也是字符串
var value = [1,2,3,4,5];
value.reverse();
console.log(value) //[5, 4, 3, 2, 1]
var values = [0,1,5, 10, 15];
values.sort()
console.log(values) //[0, 1, 10, 15, 5]
concat() slice() splice()
// 操作方法
// concat() 法基于当前数组中的所有项创建一个新数组。也就是将新的添加到数组的末尾,最后构成新的数组。也可以传递多个数组。
var colors = ["red", "green", "blue"];
var colors2 = colors.concat("yellow", ["blcak", "brown"]);
console.log(colors); //["red", "green", "blue"]
console.log(colors2); // ["red", "green", "blue", "yellow", "blcak", "brown"]
// slice()
// 截取
// slice() 接收一个或两个参数。 既要返回项的起始和结束位置。方法不会影响原来的数组。
var colors = ["red", "green", "blue", "yellow", "purple"];
var colors2 = colors.slice(1);
var colors3 = colors.slice(1, 4);
console.log(colors2); //["green", "blue", "yellow", "purple"]
console.log(colors3); //["green", "blue", "yellow"]
// splice() 主要是向数组中部插入项
// 删除 插入 替换
var colors = ["red", "green", "blue"];
var removed = colors.splice(0, 1);
console.log(colors); // ["green", "blue"]
removed = colors.splice(1, 0,"yellow", "orange");
console.log(colors); // ["green", "yellow", "orange", "blue"]
removed = colors.splice(1, 1, "red", "pruple");
console.log(removed);// ["yellow"]
indexOf() lastIndexOf()
// indexOf() lastIndexOf()
// 没有找到的情况返回-1
var numbers = [1,2,3,4,5];
console.log(numbers.indexOf(4)) //3
some() 如果该函数对每一项返回true,着返回true
这些方法都不会修改数组的值
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
var everyResult = numbers.every(function (item, index, array) {
return (item > 2)
})
console.log(everyResult) // false
var someResult = numbers.some(function (item, index, array) {
return (item > 2)
})
console.log(someResult) // true
var filterResult = numbers.filter(function (item, index, array) {
return (item > 2)
})
console.log(filterResult) // [3, 4, 5, 4, 3]
var mapResult = numbers.map(function (item, index, array) {
return item * 2
})
console.log(mapResult) // [2, 4, 6, 8, 10, 8, 6, 4, 2]
// forEach()方法 只是对数组中的每一项运行传入的函数,这个方法没有返回值。
// 本质上与使用for循环迭代数组一样
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
numbers.forEach(function(item, indx, array) {
// 执行操作
})
reduce() reduceRight()
// reduce() reduceRight()
// 使用reduce() 方法可以执行求数组中所有值之和的操作
var values = [1, 2, 3, 4, 5];
var sum = values.reduce(function (prev, cur, index, array) {
return prev + cur;
})
console.log(sum) // 15
var values = [1, 2, 3, 4, 5];
var sum = values.reduceRight(function (prev, cur, index, array) {
return prev + cur;
})
console.log(sum) // 15
JavaScript学习总结(一)--JavaScript数组
标签:last 数组 foreach block sum 截取 排序 参数 ora
原文地址:https://www.cnblogs.com/zhtian/p/9712468.html