资讯专栏INFORMATION COLUMN

js中数组操作

Terry_Tai / 3080人阅读

摘要:使用两种方式实现刘备张飞关羽通过循环累加刘备张飞关羽可以把数组中的元素链接成字符串刘备张飞关羽将一个字符串数组的元素的顺序进行反转。

数组API

API: Application Programming Interface,应用程序编程接口;

js中对象提供的方法就叫做API;

instanceof
检测一个对象是否是数组;(用来对付复杂数据类型;)
// 简单数据类型 typeof ;
A instanceof B  // A是不是B造出来的;
例:
    var arr = [1,2,3];
    console.log(arr instanceof Array); //arr属不属于Array类型;
Array.isArray( )
Array.isArray(参数); // 判断参数是不是数组,返回布尔值;
例:
    var arr = [1,2,3];
    var num = 123;
    console.log(Array.isArray(arr)); //true
    console.log(Array.isArray(num)); //false
toString( )
数组.toString(); // 把数组变成字符串,去除了[],内容用逗号链接;
例:
    var arr = ["aaa","bbb","ccc"];
    console.log(arr.toString());      //返回 aaa,bbb,ccc
valueOf( )
数组.valueOf();  //返回数组本身;   
例:
    var arr = ["aaa","bbb","ccc"];
    console.log(arr.valueOf());      //返回数组本身  ["aaa","bbb","ccc"]
数组.join(参数)
数组.join(参数);  // 数组中的元素可以按照参数进行链接变成一个字符串;
console.log(arr.join());    //和toString()一样用逗号链接
console.log(arr.join("|")); //用参数链接
console.log(arr.join("&")); //用参数链接
console.log(arr.join(" ")); //如果是空格,真的用空格链接
console.log(arr.join(""));  //空字符是无缝连接
数组元素的添加和删除 push( )和pop( )
1. 数组.push() //在数组的最末尾添加元素;
2. 数组.pop()  //不需要参数;在数组的最末尾删除一项;
例:
    var arr = [1,2,3];
    var aaa = arr.push("abc");//在数组的最末尾添加一个元素;
    console.log(arr);//元素被修改了
    console.log(aaa);//返回值是数组的长度;

    aaa = arr.pop();//不需要参数;在数组的最末尾删除一项;
    console.log(arr);//元素被修改了
    console.log(aaa);//被删除的那一项
unshift( )和shift( )
1. 数组.unshift() //在数组的最前面添加一个元素;
2. 数组.shift()  //不需要参数;在数组的最前面删除一项;
例:
    var arr = [1,2,3];
    aaa = arr.unshift("abc");//在数组的最前面添加一个元素;
    console.log(arr);//元素被修改了
    console.log(aaa);//返回值是数组的长度;

    aaa = arr.shift();//不需要参数;在数组的最前面删除一项;
    console.log(arr);//元素被修改了
    console.log(aaa);//被删除的那一项
数组元素排序 reverse( )
reverse()   //翻转数组
例:
    var arr1 = [1,2,3,4,5];
    var aaa = arr1.reverse(); // [5,4,3,2,1]
sort( )
sort() // 数组中元素排序;(默认:从小到大)
      //  默认:按照首个字符的Unicode编码排序;如果第一个相同那么就比较第二个...
例:        
    var arr = [4,5,1,3,2,7,6];
    var aaa =arr.sort();
    console.log(aaa);          // [1, 2, 3, 4, 5, 6, 7]
    console.log(aaa === arr);// true 原数组被排序了(冒泡排序)
    //默认还可以排列字母;
    var arr2 = ["c","e","d","a","b"];
    var bbb = arr2.sort();
    console.log(bbb);         // ["a", "b", "c", "d", "e"]
    console.log(bbb===arr2); // true 原数组被排序了(冒泡排序)

sort() //数值大小排序方法,需要借助回调函数;
例:
      var arr = [4,5,1,13,2,7,6];
      //回调函数里面返回值如果是:参数1-参数2;升幂;   参数2-参数1;降幂;
      arr.sort(function (a,b) {
        return a-b; //升序
        //return b-a; //降序
        //return b.value-a.value; //按照元素value属性的大小排序;
      });
      console.log(arr); // [1, 2, 4, 5, 6, 7, 13]
sort( )底层原理
    var aaa = bubbleSort([1,12,3], function (a,b) {
//        return a-b;//实参:array[j]-array[j+1];
        return b-a;//实参:array[j+1]-array[j];
    });
    console.log(aaa);

    function bubbleSort(array,fn){
        //外循环控制轮数,内循环控制次数,都是元素个数-1;
        for(var i=0;iarray[j+1]){//大于升幂排序;否则降幂;
                //a-b>0  和  a>b是一个意思;
                //b-a>0  和  a0){//升幂排序
//                if(array[j+1]-array[j]>0){//降幂排序
                //把两个变量送到一个函数中;
                if(fn(array[j],array[j+1])>0){
                    var temp = array[j];
                    array[j] = array[j+1];
                    array[j+1] = temp;
                }
            }
        }
        //返回数组
        return array;
    }
数组元素的操作 concat( )
数组1.concat(数组2); // 链接两个数组;
var arr1 = [1,2,3];
var arr2 = ["a","b","c"];
var arr3 = arr1.concat(arr2);
console.log(arr3)   //    [1, 2, 3, "a", "b", "c"]
slice( )
数组.slice(开始索引值,结束索引值);     //数组截取;
例 :
      var arr = [1, 2, 3, "a", "b", "c"];
      console.log(arr.slice(3));            //从索引值为3截取到最后;["a", "b", "c"]
      console.log(arr.slice(0,3));            //包左不包右;[1, 2, 3]
      console.log(arr.slice(-2));            //负数是后几个;["b", "c"]
      console.log(arr.slice(3,0));            //如果前面的比后面的大,那么就是[];[]
      console.log(arr);                          //原数组不被修改;[1, 2, 3, "a", "b", "c"]
splice( )
数组.splice(开始索引值,删除几个,替换内容1,替换内容2,...);  // 替换和删除;
                                                      //改变原数组;返回值是被删除/替换的内容
例:
    var arr = [1,2,3,4,5,6,"a", "b", "c"]
    arr.splice(5);        //从索引值为3截取到最后;(删除)
    console.log(arr);     // [1, 2, 3, 4, 5]
    arr.splice(1,2);    //(删除指定个数)从索引为1的开始删除2个
    console.log(arr);   //[1, 4, 5]

//替换
    var arr = [1,2,3,4,5,6,"a", "b", "c"];
    console.log(arr.splice(3,3,"aaa","bbb","ccc"));    //(删除指定数并替换)
    console.log(arr);     // [1, 2, 3, "aaa", "bbb", "ccc", "a", "b", "c"]
//    添加
    arr.splice(3,0,"aaa","bbb","ccc");//(删除指定个数)
//
    console.log(arr);//截取或者替换之后的;   [1, 2, 3, "aaa", "bbb", "ccc", "aaa", "bbb", "ccc", "a", "b", "c"]
indexOf / lastIndexOf
数组.indexOf(元素);      // 给元素,查索引(从前往后)
数组.lastIndexOf(元素);  // 给元素,查索引(从后往前)
例:
    var arr = ["a","b","c","d","c","b","b"];
    console.log(arr.indexOf("b"));        // 1 查到以后立刻返回
    console.log(arr.lastIndexOf("b"));    // 6 找到以后立刻返回
    console.log(arr.indexOf("xxx"));    // -1;  查不到就返回-1;
数组迭代(遍历) every()
对数组中每一项运行回调函数,如果都返回true,every返回true,
如果有一项返回false,则停止遍历 every返回false;不写默认返回false
像保镖失误一次,游戏结束!!!
例:
1.    var arr = [111,222,333,444,555];
    arr.every(function (a,b,c) {
        console.log(a);    //元素
        console.log(b);    //索引值
        console.log(c);    //数组本身;
        console.log("-----");    //数组本身;
        //数组中元素赋值:c[b] = 值;      a=有时候无法赋值;
        return true;
    });

2.  //every返回一个bool值,全部是true才是true;有一个是false,结果就是false
    var bool = arr.every(function (element, index, array) {
        //判断:我们定义所有元素都大于200;
        //if(element > 100){
        if(element > 200){
            return true;
        }else{
            return false;
        }
    })
    alert(bool); //false
filter()
//   对数组中每一项运行回调函数,该函数返回结果是true的项组成的新数组
//     新数组是有老数组中的元素组成的,return为ture的项;
例:
    var arr = [111,222,333,444,555];
    var newArr = arr.filter(function (element, index, array) {
        //只要是奇数,就组成数组;(数组中辨别元素)
        if(element%2 === 0){
            return true;
        }else{
            return false;
        }
    })

    console.log(newArr); // [222, 444]
forEach()
// 和for循环一样;没有返回值;
例:
    var arr = [111,222,333,444,555];
    var sum = 0;
    var aaa = arr.forEach(function (element,index,array) {
        console.log(element); // 输出数组中的每一个元素
        console.log(index); // 数组元素对应的索引值
        console.log(array); // 数组本身 [111, 222, 333, 444, 555]
        sum += element; //数组中元素求和;
    });
    console.log(sum); // 数组元素加起来的和
    console.log(aaa);//undefined;没有返回值 所以返回undefined
map()
//  对数组中每一项运行回调函数,返回该函数的结果组成的新数组
//    return什么新数组中就有什么; 不return返回undefined; 对数组二次加工
例:
    var arr = [111,222,333,444,555];
    var newArr = arr.map(function (element, index, array) {
        if(index == 2){
            return element; // 这里return了 所以下面返回的值是333
        }
        return element*100; // 返回的元素值都乘上100后的值
    })
    console.log(newArr); // [11100, 22200, 333, 44400, 55500]
some()
//对数组中每一项运行回调函数,如果该函数对某一项返回true,则some返回true; 像杀手,有一个成功,就胜利了!!!
例:
    var arr = [111,222,333,444,555];
    var bool = arr.some(function (ele,i,array) {
        //判断:数组中有3的倍数
        if(ele%3 == 0){
            return true;
        }
        return false;
    })
    alert(bool); //true ; 有一个成功就是true
数组清空
    1. arr.length = 0; // (不好,伪数组无法清空)
    2. arr.splice(0); // 伪数组没有这个方法;
    3. arr = [];     // 可以操作伪数组; (推荐!)
// 伪数组: 就是长的像数组,但是没有数组的方法;也不能添加和删除元素;
例: // arguments
        fn(111,222,333);
        function fn(){
            arguments.length = 0; // 无法清空 返回 [1, 2, 3]
           arguments.splice(0); // 会报错 arguments.splice is not a function
            arguments = []; // 可以清空,返回空数组[] 
            console.log(arguments);
        }

数组案例

1.将一个字符串数组输出为|分割的形式,比如“刘备|张飞|关羽”。使用两种方式实现

       var arr = ["刘备","张飞","关羽"];
       var separator = "|";
       //通过for循环累加
       var str = arr[0];
       for(var i=1;i

2.将一个字符串数组的元素的顺序进行反转。["a", "b", "c", "d"] -> [ "d","c","b","a"]。使用两种种方式实现。提示:第i个和第length-i-1个进行交换

  // 数组.reverse() 方法
           var arr = ["a", "b", "c", "d"];
           console.log(arr.reverse()); // ["d", "c", "b", "a"]
       
       //  三种:1.正向遍历,反向添加;  2.反向遍历,正向添加;   3.元数组元素交换位置;
           for(var i=0;i

3.工资的数组[1500, 1200, 2000, 2100, 1800],把工资超过2000的删除

   var arr = [1500, 1200, 2000, 2100, 1800];
   //利用filter()形成一个数组;return true;组成的数组;
   var newArr = arr.filter(function (ele, i, array) {
       //2000以上返回false;
       if(ele<2000){
           return true;
       }else{
           return false;
       }
   });
   console.log(newArr); // [1500, 1200, 1800]

4.["c", "a", "z", "a", "x", "a"]找到数组中每一个a出现的位置

   var arr = ["c", "a", "z", "a", "x", "a"];
   //遍历数组(for/while/do...while)    forEach();
   arr.forEach(function (ele, index, array) {
       //如果元素等于“a”,那么就输出索引值;
       if("a" === ele){
           console.log(index);
       }
   });

5.编写一个方法去掉一个数组的重复元素 (数组去重)

       var arr = ["鸣人","鸣人","佐助","佐助","小樱","小樱"];
   //  方法1:  思路:定义一个新数组,遍历老数组,判断,如果新数组里面没有老数组的元素就添加,否则就不添加;
       var newArr = [];
       //遍历老数组
       arr.forEach(function (ele,index,array) {
           //检测老数组中的元素,如果新数组中存在就不添加了,不存在才添加;
           if(newArr.indexOf(ele) === -1){//不存在就添加;(去新数组中查找元素索引值,如果为-1就是没有)
               newArr.push(ele);
           }
       });
       console.log(newArr); // ["鸣人", "佐助", "小樱"]
       
       也可以利用ES6中的Set方法达到快速去重,一行代码解决:
       
       [...new Set(arr)] 或者:Array.from(new Set(arr)) // ["鸣人", "佐助", "小樱"]




文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/90173.html

相关文章

  • 用好JS 原生API系列之数组

    摘要:函数的因为也拥有属性,所以其被称为类数组对象。方法数组的拼接,,指被拼接的对象数组,为数组。如果为负,则将其视为,其中为数组的长度。而提供了数组反转和排序来对数组进行重排序。用好原生,你的代码将显得干净,有趣。 前言 最近工作做数据交互展示,常和数据打交道,而随之而来的就是遇见后端传来的各种各样的数组,我需要用各式各样的方法来变换这些数据,来最好的展示这些数据;很多东西久了没用就容易忘...

    shenhualong 评论0 收藏0
  • PHP: array数组常用API

    摘要:语法数组删除数组的最后一项语法数组在数组的最末添加一项语法数组删除数组的首项语法数组在数组的首部添加一项案例分析 1:数组的指针操作: 语法:current(数组) 当前指针指向的单元值(默认是第零个)语法 next(数组) 当前指针往下移动一帧语法 prev(数组) 当前指针往前移动一个指针语法 end(array) 将当前指针移动到最后一项语法 ...

    Cheriselalala 评论0 收藏0
  • 聊聊在javascript数组的使用

    摘要:在中,数组里可以容纳容纳中任何类型的值。方法大全在中数组是可修改的对象,每个数组都有着很多好用的方法,大多数我们日常都会常用。把元素添加到数组的头部。利用使用下标进行操作。对当前数组中的每一项运行给定的函数返回函数结果为的项组成的数组。 杂谈     数组是最简单的内存数据结构,也是js中最常用的类型之一,整理了下我觉得应该了解数组的相关知识。 在js中,数组里可以容纳容纳js中任何...

    zone 评论0 收藏0
  • 对类型化数组(Typed Array)与ArrayBuffer的理解

    摘要:类型化数组也是中新引入的。用一句话解释类型化数组就是它是操作二进制数据的接口。类型化数组类型化数组的应用二进制数据的接口主要应用于文件,在中涉及文件处理的几乎都可以应用,主要是,,。 类型化数组(Typed Array)也是HTML5中新引入的API。用一句话解释类型化数组就是:它是JS操作二进制数据的接口。 众所周知,直接操作二进制数据可以使程序更为高效, 尽管JS对常规数组做了很多...

    Worktile 评论0 收藏0
  • JS学习第十天笔记 Array类型

    摘要:只有满足才返回,否则返回。专门用于筛选出数组中符合函数判断条件的元素组成的心数组。专门用于对原数组中每个元素执行相同的函数对象规定的操作。并归方法将数组从左向右迭代。 Array类型 数组的常见方法 检测数组 如何确定当前是一个数组,JS提供了以下几种方式1.typeof无法检测数组对象:typrof[]返回object2.instanceof:[]instanceof Array返回...

    Barrior 评论0 收藏0
  • js基本操作-数组去重

    摘要:基本操作数组去重数组去重的方法临时数组保存其实这里面还没考虑到数组里面嵌套数组对象的情况把去重后的结果放在一个临时数组中对原来数组的元素与临时数组元素比较临时数组中不存在这个元素的放入临时数组。 js基本操作-数组去重 数组去重的方法 1. 临时数组保存(其实这里面还没考虑到数组里面嵌套数组/对象的情况) 把去重后的结果放在一个临时数组中, 对原来数组的元素与临时数组元素比较, 临时...

    GeekGhc 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<