Js Array数组方式总结

访客3年前黑客文章688

合并数组 - concat()

用法一 (合并两个数组)

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()、toString()

两种方式都返回新的字符串

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()

pop 返回米素的最后一个米素,原数组最后一个删除。

var fruits = ["Banana", "Orange", "Apple", "Mango"];

var a = fruits.pop();

console.log(a);                //  "Mango"

console.log(fruits );          //  ["Banana", "Orange", "Apple"]


添加米素 - push()

push 返回的是数组的长度,原数组最后面添加一个新米素

var fruits = ["Banana", "Orange", "Apple", "Mango"];

var a = fruits.push("Kiwi");

console.log(a);                // 5

console.log(fruits);          //   ["Banana", "Orange", "Apple", "Mango", "Kiwi"]


数组反转 - reverse()

var fruits = ["Banana", "Orange", "Apple", "Mango"];

fruits.reverse();

console.log(fruits);        // ["Mango", "Apple", "Orange", "Banana"]


删除数组之一个米素 - shift()

shift 返回数组的之一个米素,原数组之一个米素被删除

var fruits = ["Banana", "Orange", "Apple", "Mango"];

var a= fruits.shift();

console.log(a);              //  "Banana"

consoel.log(fruits);        //   ["Orange", "Apple", "Mango"]


截取数组米素 - slice(start,end)

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(func)

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( start, count , .....)

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"]


在数组开头添加米素 - unshift()

var fruits = ["Banana", "Orange", "Apple", "Mango"];

fruits.unshift("Lemon","Pineapple");

console.log(fruits);            // ["Lemon", "Pineapple", "Banana", "Orange", "Apple", "Mango"]


检查某米素是否存在于数组中 - indexOf()、lastIndexOf()

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


数组遍历 - map()、forEach()

相同点:

  • 都是数组的遍历方式,可以遍历数组中的每一个米素

  • 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()

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]


of 遍历

let arr2=[1,2,234,'sdf',-2];

for(let a of arr2){

  console.log(a)          // 1,2,234,sdf,-2 遍历了数组arr的值

}


数组累加器 - reduce()、reduceRight()

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()

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


将当前数组指定位置的米素复制到其他位置并替换 - copyWithin(index,start,end)

index(必须):从该位置更先替换数据。若是为负值,示意倒数。

start(可选):从该位置更先读取数据,默以为 0。若是为负值,示意倒数。

end(可选):到该位置前住手读取数据,默认即是数组长度。使用负数可从数组末端处划定位置。

[1, 2, 3, 4, 5].copyWithin(0,1,3)    //   [2, 3, 3, 4, 5]


*** ON数组花样转换 - Array.from()

Array.from() 转换的 json 要求必须要有length属性

let  people = {

    0:'zhangsan',

    '1':24,   

    length:2   

};

let trans=Array.from(people);

console.log(trans);            //  ['zhangsan',24]


将一堆米素转换成数组 - Array.of()

let arr = Array.of(1,"23","测试","dsa"); 

console.log(arr);            //  [1, "23", "测试", "dsa"]


查找数组中知足条件的米素 - find()

let arr=[1,2,3,"cxz",-2];

var a = arr.find(function(x){

  return x<="cxz";

});

console.log(a);              // "cxz"


查找数组中知足条件的米素的下标 - findIndex()

let arr=[1,2,3,"cxz",-2];

var a = arr.findIndex(function(x){

  return x<="cxz";

});

console.log(a);              // 3


判断数组中是否包罗某米素 - includes()

includes 判断数组中是否包罗某米素,返回布尔值

let arr=[1,2,3,"cxz",-2];

var a = arr.includes("cxz");

console.log(a);              //  true
思源资源网:分类流动

1.阿里云: 本站现在使用的是阿里云主机,平安/可靠/稳固。点击领取2000米代金券、领会最新阿里云产物的种种优惠流动点击进入

相关文章

手指上长倒刺很是因为什么原因?经常啃指甲还是指甲周围皮肤干燥

手指上长倒刺很是因为什么原因?经常啃指甲还是指甲周围皮肤干燥

手指上长倒刺,很可能是因为?这是蚂蚁庄园7月14号今日庄园小课堂的问题,很多用户还不知道答案,本文小编会为大家详细介绍,感兴趣的小伙伴们,一起和小编来看看吧! 蚂蚁庄园回答知识送饲料活动开始啦!...

一元一次手机定位软件网站(免费定位)

一元一次手机位置软件网站(免费定位)1.0版处理快的难题,2.0版处理又快又准的难题,是1.0基本上的一个极大升級!10月14日,在北斗导航卫星网站导航峰会上,我国通信网络研究所(下通称“信通院”)公...

记忆卡数据恢复

打开软件,挑选U盘/电话卡/照相机卡,点一下逐渐扫描仪,等候扫描仪进行,挑选修复的基本数据类型,启用要修复的文档,点一下逐渐修复,设定好修复途径,点一下逐渐修复就可以。 知名品牌型号规格:想到Geek...

康熙太子(溥仪说过雍正继位真相)

康熙太子(溥仪说过雍正继位真相) 在清初,努尔哈赤、皇太极和福临其实生前都没有立太子,而且清朝只有康熙帝玄烨生前就立了太子,雍正帝胤禛之后是秘密立储。人们评价康熙在政治上取得了辉煌的成就,称他为千古...

怎么知道女朋友微信跟谁聊天【异地怎么查对象微信聊天记录】

如何判断女友手机微信跟谁闲聊 怎么知道一个女人是不是随意?使我们看一下她是不是应用这三种微信聊天方法,如今这一社会发展充满了各式各样的人。无论是女性還是男生,都是有一些渣男男人渣男女性。有一些女性给...

黑客攻击最高层次是(从攻击过程的角度来讲,黑客的攻击一般分为)

黑客攻击最高层次是(从攻击过程的角度来讲,黑客的攻击一般分为)

本文导读目录: 1、黑客分为哪几个等级 2、黑客的等级是如何划分的? 3、简述黑客攻击的分类情况。 4、从统计的情况看 造成危害最大的黑客攻击是漏洞攻击吗 5、现在最流行的黑客攻击是什...