【监测数组】

  1. 使用instanceof操作符,进行检测

    ar arr = [1,2,3];
    // arr = '非非';
    if(arr instanceof Array){
    console.log('是数组');
    }else{
    console.log('不是数组');
    }

    备注:ES3中使用instanceof操作符的前提是,当前页面只有一个执行环境,当网页中存在多个框架的时候,这种检测方式出现问题;为了解决这个问题,ES5提出了第二种方法

  2. Array.inArray()方法
    var arr = [1,2,3];
    // arr = '非非';
    if(Array.isArray(arr)){
    console.log('是数组');
    }else{
    console.log('不是数组');
    }

    备注:IE8是不支持这种检测的,当然了对于其兼容性还是可以实现的;不过现在对于IE8早已无人问津

【数组转换字符串】

  1. toString()方法

    var arr = [
    [1,2,3],
    ['非非','咖啡'],
    [8,9]
    ];
    console.log(arr.toString());//1,2,3,非非,咖啡,8,9
  2. join()方法
    var arr = [
    [1,2,3],
    ['非非','咖啡'],
    [8,9]
    ];
    console.log(arr.join(','));//1,2,3,非非,咖啡,8,9
    console.log(arr.join('||'));//1,2,3||非非,咖啡||8,9

【数组排序】

  1. reverse()反转数组项的顺序

    var arr = [1,2,3,4];
    var arr1 = ['非非','琪琪','艾艾'];
    console.log(arr.reverse());//[4, 3, 2, 1]
    console.log(arr1.reverse());//["艾艾", "琪琪", "非非"]
  2. sort()
    1. 默认情况下,按升序排列数组项(默认比较的是每一项的字符串形式,toString())

      var arr = [1,2,3,4];
      var arr1 = ['非非','琪琪','艾艾'];
      var arr2 = [1,2,3,4,11];
      console.log(arr.sort());//[1, 2, 3, 4]
      console.log(arr1.sort());// ["琪琪", "艾艾", "非非"]
      console.log(arr2.sort());//[1, 11, 2, 3, 4]
    2. sort()接受一个比较函数的参数
      function compare(value1, value2){
      if(value1 < value2){
      return -1;
      }else if(value1 > value2){
      return 1;
      }else{
      return 0;
      }
      }
      // 简化比较函数
      function compare(value1, value2){
      return value1 - value2;
      }
      var arr = [1,2,3,4,11];
      console.log(arr.sort(compare));//[1, 2, 3, 4, 11]

【数组插入】

  1. push()从后面插入新项

    var arr = [1,2,3,4];
    arr.push(8,9)
    console.log(arr);//[1, 2, 3, 4, 8, 9]
  2. unshift()从前面插入新项
    var arr = [1,2,3,4];
    arr.unshift(8,9)
    console.log(arr);//[8, 9, 1, 2, 3, 4]
  3. splice()-插入
    var arr = [1,2,3,4,5];
    arr.splice(3,0,'非非')
    console.log(arr);//[1, 2, 3, "非非", 4, 5]

【数组删除】

  1. pop()删除数组最后一项

    var arr = [1,2,3,4];
    arr.pop()
    console.log(arr);//[1, 2, 3]
  2. shift()删除数组第一项
    var arr = [1,2,3,4];
    arr.shift()
    console.log(arr);//[2, 3, 4]
  3. splice()-删除
    var arr = [1,2,3,4,5,6,7,8,9];
    arr.splice(0,3)
    console.log(arr);//[4, 5, 6, 7, 8, 9]

【数组替换】

splice()-替换

var arr = [1,2,3,4,5];
arr.splice(2,1,'非非','琪琪')
console.log(arr);//[1, 2, "非非", "琪琪", 4, 5]

【数组位置查找】

var arr = [1,2,'非非',3,4,5,'非非','琪琪'];
console.log(arr.indexOf('非非'));//
console.log(arr.lastIndexOf('非非'));//

【数组合并】

concat()

var arr = [1,2,3,4,11];
var arr1 = ['非非','琪琪'];
console.log(arr.concat(arr1));// [1, 2, 3, 4, 11, "非非", "琪琪"]
console.log(arr1.concat(arr));//["非非", "琪琪", 1, 2, 3, 4, 11]

【数组截取】

slice(),接收一个或两个参数,第一个参数是数组起始位置(结果包括起始位置项),第二个参数是结束位置(结果不包括结束项);支持负数,用长度length减去负数,就是当前项的位置

var arr = [1,2,3,4,5,6,7,8,9];
console.log(arr.slice(1));//[2, 3, 4, 5, 6, 7, 8, 9]
console.log(arr.slice(1,5));//[2, 3, 4, 5]
console.log(arr.slice(-3));//[7, 8, 9]
console.log(arr.slice(-4,-1));//[6, 7, 8]

【迭代方法】

  1. every()对数组中的每一项运行给定函数,如果该函数对每一项都返回true,则返回true

    var arr = [1,2,3,4,5,6,7,8];
    var everyMethods = arr.every(function(item, index, array){
    return item > 0;
    });
    console.log(everyMethods);//true
  2. filter()对数组中的每一项运行给定函数,返回该函数会返回true的项组成的数组
    var arr = [1,2,3,4,5,6,7,8];
    var filterMethods = arr.filter(function(item, index, array){
    return item > 6;
    });
    console.log(filterMethods);//[7, 8]
  3. forEach()对数组中的每一项运行给定函数。这个方法没有返回值(与使用for循环迭代数组一样)
    var arr = [1,2,3,4,5,6,7,8];
    var forEachMethods = arr.forEach(function(item, index, array){
    console.log('item=>'+item);
    console.log('index=>'+index);
    console.log('array=>'+array);
    });
    console.log(forEachMethods);
    // item=>1
    // array.html:24 index=>0
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>2
    // array.html:24 index=>1
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>3
    // array.html:24 index=>2
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>4
    // array.html:24 index=>3
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>5
    // array.html:24 index=>4
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>6
    // array.html:24 index=>5
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>7
    // array.html:24 index=>6
    // array.html:25 array=>1,2,3,4,5,6,7,8
    // array.html:23 item=>8
    // array.html:24 index=>7
    // array.html:25 array=>1,2,3,4,5,6,7,8
  4. map()对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组
    var arr = [1,2,3,4,5,6,7,8];
    var mapMethods = arr.map(function(item, index, array){
    return item*2;
    });
    console.log(mapMethods);//[2, 4, 6, 8, 10, 12, 14, 16]
  5. some()对数组中的每一项运行给定函数,如果该函数对任一项返回true,则返回true
    var arr = [1,2,3,4,5,6,7,8];
    var someMethods = arr.some(function(item, index, array){
    return item > 6;
    });
    console.log(someMethods);//true

【归并方法】

reduce()方法 and reduceRight()方法

这两个方法,目前所知的使用方法比较简单,在实际的开发中,完全可以采用其他方式达到这种效果,就先养着吧,万一那一天我明白了,再补上

JavaScript中数组的各种操作方法的更多相关文章

  1. JavaScript中数组操作常用方法

    JavaScript中数组操作常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2 ...

  2. javascript中数组Array的方法

    一.常用方法(push,pop,unshift,shift,join)push pop栈方法,后进先出var a =[1,2,3];console.log(a.push(40)); //4 返回数组的 ...

  3. Javascript中数组

    Javascript中数组 1.什么是数组 所谓的数组就是一组数据的集合,在内存中表现为一段连续的内存地址(保存在堆内存) 2.创建数组的含义 创建数组的目的:就是为了保存更多的数据 3.数组的定义 ...

  4. javascript中数组常用方法总结

    原文:javascript中数组常用方法总结 在javascript的基础编程中,数组是我们最常遇到的,那么数组的一些常用方法也是我们必须要掌握的,下面我们总结一下数组中常用的方法. toString ...

  5. JavaScript中数组Array方法详解

    ECMAScript 3在Array.prototype中定义了一些很有用的操作数组的函数,这意味着这些函数作为任何数组的方法都是可用的. 1.Array.join()方法 Array.join()方 ...

  6. javascript中数组的常用算法深入分析

    Array数组是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array是前端必修的功课.本文将给大家详细介绍了javascri ...

  7. javascript中数组化的一般见解

    javascript中数组化的一般见解,数组化浏览器中存在许多类数组对象,往往对类数组操作比较麻烦,没有数组那些非常方便的方法,在这种情况下,就有了数组化方法. 数组化的一般方法 1.第一种也是我们最 ...

  8. 总结Javascript中数组各种去重的方法

    相信大家都知道网上关于Javascript中数组去重的方法很多,这篇文章给大家总结Javascript中数组各种去重的方法,相信本文对大家学习和使用Javascript具有一定的参考借鉴价值,有需要的 ...

  9. JavaScript中数组常用方法的总结

    JavaScript中数组Array常用的方法总结 标签(空格分隔): JavaScript ECMAScript数组给我们提供了许多常用的方法,便于我们对数组进行操作,下面,就来总结一下这些方法. ...

随机推荐

  1. C/C++面试题目一

    C/C++开发工程师面试题目(一)(附答案分析) 推荐:自己根据在面试中碰到做过的一些题目以及总结的题目,希望对面试的同学有所帮助. 一. 选择题 1. 下列类中(  )不是输入输出流类iostrea ...

  2. 教你如何更改android应用的包名

    Android 源码自带了很多应用程序,想改个包名方便修改?很简单,两步搞定,以packages/apps/Settings为例: 1.打开AndroidManifest.xml,把 <mani ...

  3. Hadoop HDFS 单节点部署方案

    初学者,再次记录一下. 确保Java 和 Hadoop已安装完毕(每个人的不一定一样,但肯定都有数据,仅供参考) [root@jans hadoop-2.9.0]# pwd /usr/local/ha ...

  4. 洛谷 P2708 硬币翻转 题解

    题目传送门 真如题面所说,难度系数:☆☆☆☆☆(如果你看懂了). 从后往前扫一次,如果a[i]==0&&a[i-1]==1那么将ans+2. 注意最后不要忘记开头if(a[0]=='0 ...

  5. [loj6039]「雅礼集训 2017 Day5」珠宝 dp+决策单调性+分治

    https://loj.ac/problem/6039 我们设dp[i][j]表示考虑所有价值小于等于i的物品,带了j块钱的最大吸引力. 对于ci相同的物品,我们一定是从大到小选k个物品,又发现最大的 ...

  6. LCA:倍增与tarjan

    学了好久(一两个星期)都没彻底搞懂的lca,今天总算理解了.就来和大家分享下我自己的心得 首先,如果你还不懂什么是lca,出门左转自行百度 首先讲倍增 倍增的思想很简单,首先进行预处理,用一个深搜将每 ...

  7. 安装与配置ironic

    安装及配置 由于Ironic的配置很长,下面我们简短的说一下安装和配置过程,具体的安装配置教程参考官方手动配置教程或者使用devstack安装. Ironic需要与Nova.Neutron.Glanc ...

  8. bound和unbound方法,类的绑定和非绑定是什么

    作者:灵剑链接:https://www.zhihu.com/question/41006598/answer/148994582来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  9. POJ 1498[二分匹配——最小顶点覆盖]

    题目链接:[http://acm.hdu.edu.cn/showproblem.php?pid=1498] 题意:给出一个大小为n*n(0<n<100)的矩阵,矩阵中放入m种颜色(标号为1 ...

  10. POJ3710 Christmas Game 博弈论 sg函数 树的删边游戏

    http://poj.org/problem?id=3710 叶子节点的 SG 值为0:中间节点的SG值为它的所有子节点的SG值加1后的异或和. 偶环可以视作一个点,奇环视为一条边(连了两个点). 这 ...