var hege = ["Cecilie", "Lone"]; var stale = ["Emil", "Tobias", "Linus"]; var children = hege.concat(stale); console.log(children ); // ["Cecilie", "Lone", "Emil", "Tobias", "Linus"]
var parents = ["Jani", "Tove"]; var brothers = ["Stale", "Kai Jim", "Borge"]; var children = ["Cecilie", "Lone"]; var family = parents.concat(brothers, children); console.log(family); // ["Jani", "Tove", "Stale", "Kai Jim", "Borge", "Cecilie", "Lone"]
两种方式都返回新的字符串
join() 方式
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.join(); console.log(a); // "Banana,Orange,Apple,Mango"
toString() 方式
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.toString(); console.log(a); // "Banana,Orange,Apple,Mango"
相同点:
都可以将数组转字符串。
区别:
join另有另外的用法:join() 可接受一个参数作为米素之间的毗邻符号
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.join("-"); console.log(a); // "Banana-Orange-Apple-Mango"
pop 返回米素的最后一个米素,原数组最后一个删除。
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.pop(); console.log(a); // "Mango" console.log(fruits ); // ["Banana", "Orange", "Apple"]
push 返回的是数组的长度,原数组最后面添加一个新米素
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.push("Kiwi"); console.log(a); // 5 console.log(fruits); // ["Banana", "Orange", "Apple", "Mango", "Kiwi"]
var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.reverse(); console.log(fruits); // ["Mango", "Apple", "Orange", "Banana"]
shift 返回数组的第一个米素,原数组第一个米素被删除
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a= fruits.shift(); console.log(a); // "Banana" consoel.log(fruits); // ["Orange", "Apple", "Mango"]
slice 返回截取的米素组成的数组,原数组不会发生变化。
slice接受两个参数,起始位置和竣事位置,第一个参数起始位置若是为负数,示意从数组尾部最先算,如 -1 代表最后一个。若是不传入竣事位置,示意从起始位置起到数组末端的所有米素。
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"]; var a= fruits.slice(1,3); console.log(a); // ["Orange", "Lemon"] console.log(fruits); // ["Banana", "Orange", "Lemon", "Apple", "Mango"]
sort 方式用于对数组的米素举行排序。
sort 可接受一个参数 func,非必传,若是要传入必须是函数,在不传参的情况下,sort 示意按字符串编码的顺序举行排序,若是要对数组举行排序需传入函数。
不传参:
var arr= ["George", "John", "Thomas", "James", "Adrew", "Martin"]; arr.sort(); console.log(fruits); // ["Adrew", "George", "James", "John", "Martin", "Thomas"] // 没有传入函数,以是结果是根据0123456789的顺序举行排列 var nums = [21,14,26,11,105]; nums.sort(); console.log(nums); // [105, 11, 14, 21, 26]
传参:
function sortNumber(a, b){ return a - b } var nums = [21,14,26,11,105]; nums.sort(sortNumber); console.log(nums); // [11, 14, 21, 26, 105]
splice 接受多个参数,第一个是起始位置,第二个为删除个数,之后的参数为添加/删除/替换的米素。
splice 返回删除米素的数组
var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.splice(2,0,"Lemon","Kiwi"); console.log(fruits ); // ["Banana", "Orange", "Lemon", "Kiwi", "Apple", "Mango"]
// 从第二个位置起删除两个米素,接受新的两个米素 var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.splice(2,2,"Lemon","Kiwi"); console.log(a); // ["Apple", "Mango"] console.log(fruits); // ["Banana", "Orange", "Lemon", "Kiwi"]
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var a = fruits.splice(2,2); console.log(a); // ["Apple", "Mango"] console.log(fruits); // ["Banana", "Orange"]
var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.unshift("Lemon","Pineapple"); console.log(fruits); // ["Lemon", "Pineapple", "Banana", "Orange", "Apple", "Mango"]
indexOf 和 lastIndexOf 都接受两个参数,第一是需要检查的米素。第二个是从谁人索引位置最先检查
indexOf 示意从 0 最先,lastIndexOf 示意最后一个米素最先
var arr = [1,23,4,5,6,7,89]; arr.indexOf(89) // 6 arr.indexOf(89,2) // 6 arr.lastIndexOf(89) // 6 arr.lastIndexOf(89,5) // -1
相同点:
都是数组的遍历方式,可以遍历数组中的每一个米素
forEach和map方式里每次执行匿名函数都支持3个参数,参数分别是item(当前每一项),index(索引值),arr(原数组)
都不会改变原数组
匿名函数的 this 都指向 windows
不同点:
map 方式会返回一个新的数组,数组中的米素为处置后的值,forEach 方式不会返回新的数组
map 方式不会对空数组举行检测,forEach对于空数组是不会调用回调函数的。
mao 方式不支持低端浏览器
var arr = [1,2,3,4]; var a = arr.map(function(item,index,arr){ return item * item; }) console.log(a); // [1, 4, 9, 16] console.log(arr); // [1, 2, 3, 4]
var arr = [1,2,3,4]; var a = arr.forEach(function(item,index,arr){ return item * item; }) console.log(a); // undefined console.log(arr); // [1, 2, 3, 4]
filter() 方式是返回某一数组中知足条件的米素,该方式返回的是一个新的数组。
// 返回米素长度大于 10 的数组米素
var arr = [12,5,8,16,125,98]; var filters = arr.filter(function(value){ return value >= 10 }); console.log(filters ); // [12, 16, 125, 98]
let arr2=[1,2,234,'sdf',-2]; for(let a of arr2){ console.log(a) // 1,2,234,sdf,-2 遍历了数组arr的值 }
reduce() 方式吸收一个函数作为累加器,数组中的每个值(从左到右)最先缩减,最终盘算为一个值。
reduce 和 reduceRight 用法一样,区别在于 reduceRight 是从数组的末尾向前做数组项累加。
array.reduce(function(total, currentValue, currentIndex, arr), initialValue); total 必须。初始值, 或者盘算竣事后的返回值。 currentValue 必须。当前米素 currentIndex 可选。当前米素的索引 arr 可选。当前米素所属的数组工具。 initialValue 初始值
var numbers = [65, 44, 12, 4]; var a = numbers.reduce(function(total,num){ return total + num; },0) console.log(a); // 125
some 方式会遍历数组的每一个米素,判断是否知足条件,返回一个布尔值。
every 方式会遍历数组的每一个米素,判断每一项是否知足条件,若是每项都知足,才返回true。
var numbers = [65, 44, 12, 4]; var a = numbers.some(function(item){ return item > 62; }); console.log(a); // true
var numbers = [65, 44, 12, 4]; var a = numbers.every(function(item){ return item > 62; }); console.log(a); // false
index(必须):从该位置最先替换数据。若是为负值,示意倒数。
start(可选):从该位置最先读取数据,默以为 0。若是为负值,示意倒数。
end(可选):到该位置前住手读取数据,默认即是数组长度。使用负数可从数组末端处划定位置。
[1, 2, 3, 4, 5].copyWithin(0,1,3) // [2, 3, 3, 4, 5]
Array.from() 转换的 json 要求必须要有length属性
let people = { 0:'zhangsan', '1':24, length:2 }; let trans=Array.from(people); console.log(trans); // ['zhangsan',24]
let arr = Array.of(1,"23","测试","dsa"); console.log(arr); // [1, "23", "测试", "dsa"]
let arr=[1,2,3,"cxz",-2]; var a = arr.find(function(x){ return x<="cxz"; }); console.log(a); // "cxz"
let arr=[1,2,3,"cxz",-2]; var a = arr.findIndex(function(x){ return x<="cxz"; }); console.log(a); // 3
includes 判断数组中是否包罗某米素,返回布尔值
let arr=[1,2,3,"cxz",-2]; var a = arr.includes("cxz"); console.log(a); // true
1.阿里云: 本站现在使用的是阿里云主机,平安/可靠/稳固。点击领取2000米代金券、领会最新阿里云产物的种种优惠流动点击进入
2.腾讯云: 提供云服务器、云数据库、云存储、视频与CDN、域名等服务。腾讯云各种产物的最新流动,优惠券领取点击进入
3.广告同盟: 整理了现在主流的广告同盟平台,若是你有流量,可以作为参考选择适合你的平台点击进入
链接: http://www.fly63.com/article/detial/3905