JavaScript学习-数组

简介: 数组

1、创建数组

    • 利用new创建一个空数组
    var arr=new array();

    image.gif

      • 利用数组字面量创建数组
      var arr=[];//创建一个空数组
      var arr1=[1,2,'green',true];//创建里面有元素的数组

      image.gif

      数组中可以存放任意类型的数据,就像上面的arr1中一样,你高兴放什么类型就放什么类型,只有格式正确就没错。

      2、获取数组元素格式

      数组名[索引号];索引号是从0开始的。

      var arr1=[1,2,'green',true];
      console.log(arr1);
      console.log(arr1[0]);
      console.log(arr1[1]);

      image.gif


      3、遍历数组(从头到尾访问一遍)

      用for循环来遍历数组,for循环中间的条件表达式最好使用数组名.length的方法,来判断,因为有的时候数组较长,这样子方便使用。

      注意这里i=0,所有在判断的时候i<arr.length 才是正确的。

      数组的长度:数组名.length动态测试数组的个数。

      var arr=['red','green','blue'];
      for(var i=0;i<arr.length;i++){
        console.log(arr[i]);
      }

      image.gif

      4、数组中新增元素

        • 通过修改length长度新增数组元素。
        var arr=['red','green','blue'];
        arr.length=5;
        console.log(arr);

        image.gif

        • 修改索引号(追加数组元素)
        var arr=['red','blue','green'];
        arr[3]='ok';
        console.log(arr);

        image.gif

        这里要注意:不要直接给数组名赋值,不然会被覆盖。


        理论知识差不多到这里,下面来看几个案例,有些方法你会意想不到。


        经典案例

        (1)求数组里面的所有元素的和以及平均值。

        思路:咱得有两个变量来存放它们的和(sum)以及平均值(average),通过遍历数组的方法把他们全都加起来,然后再除以数组的长度即可。

        var arr=[2,7,6,8,4];
        var sum=0;
        var average=0;
        for (var i=0;i<arr.length;i++){
            sum+=arr[i];
        }
        average=sum/arr.length;
        console.log(sum,average);

        image.gif

        (2)求数组最大值。

        思路:咱得用默认一个最大值,假设就是数组的第一个元素arr[0],然后用它跟后面的元素比较,如果比它大,则最大值换人变成当前这个元素,直到找到真的最大值为止。

        for循环得从arr[1]开始,因为arr[0]被假设为最大值了。

        var arr=[2,7,6,8,4,11,49,12];
        var max=arr[0];
        for (var i=1;i<arr.length;i++){
            if(arr[i]>max){
                max=arr[i];
            }
        }
        console.log('该数组里面的最大值是:'+max);

        image.gif

        (3)数组转为分割字符串(用|来分隔)

        思路:这里可以创一个新的数组,然后把旧数组放到新数组里,注意这里多了一个分隔符。

        var arr=['red','green','brown','black'];
        var str='';
        var sep='|';
        for (var i=0;i<arr.length;i++){
                str+=arr[i]+sep;
        }
        console.log(str);

        image.gif

        (4)新建一个数组存放十个整数。

        思路:用for循环,因为索引号是从0开始,但存放的整数从1开始,所有如下代码:

        var arr=[];
        for(var i=0;i<10;i++){
        arr[i]=i+1;
        }
        console.log(arr);

        image.gif


        (5)将数组[2,0,6,11,23,46,5,4,7,9,11,8]中大于10的元素选出。

          • 方法一

          思路:利用一个新的数组来存放大于10的元素。这里要设置一个新数组的索引号变量为j,j从0开始,每放进一个新元素则索引号要进行+1操作。

          var arr=[2,0,6,11,23,46,5,4,7,9,11,8];
          var newArr=[];
          var j=0;
          for(var i=0;i<arr.length;i++){
              if(arr[i]>10){
                  newArr[j]=arr[i];
                  j++;
              }
          }
          console.log(newArr);

          image.gif

            • 方法二★★★

            这里就没有新数组的索引号变量了,就直接用newArr.length来进行操作了,因为一个数组它放进去一个元素长度就会+1。.length会自动检测数组长度。

            var arr=[2,0,6,11,23,46,5,4,7,9,11,8];
            var newArr=[];
            for(var i=0;i<arr.length;i++){
                if(arr[i]>10){
                    newArr[newArr.length]=arr[i];
                }
            }
            console.log(newArr);


            (6)删除指定数组元素。

            将数组中的0去掉,形成一个新数组。

            思路:依旧是利用新旧数组的方法,把不是0的元素放入新数组里。

            var arr=[2,0,6,11,23,0,46,5,0,4,7,9,11,8];
            var newArr=[];
            for(var i=0;i<arr.length;i++){
                if(arr[i]!=0){
                    newArr[newArr.length]=arr[i];
                }
            }
            console.log(newArr);

            image.gif

            (7)翻转数组

            将数组['red','green','black','brown','pink']的内容放过来放。

            利用新旧数组,从旧数组的最后一个元素开始放,最后一个元素的索引号为arr[arr.length-1]。

            var arr=['red','green','black','brown','pink'];
            var newArr=[];
            for(var i=arr.length-1;i>=0;i--){
               newArr[newArr.length]=arr[i];
            }
            console.log(newArr);

            image.gif

            (8)数组排序(冒泡法排序)

            var arr=[5,4,3,2,1];
            for(var i=0;i<=arr.length-1;i++){
                for(var j=0;j<=arr.length-i-1;j++){
                    if(arr[j]>arr[j+1]){
                        var temp=arr[j];
                        arr[j]=arr[j+1];
                        arr[j+1]=temp;
                    }
                }
            }
            console.log(arr);


            目录
            相关文章
            |
            21天前
            |
            Web App开发 JavaScript 前端开发
            如何学习JavaScript?
            如何学习JavaScript?
            37 5
            |
            20天前
            |
            JavaScript 前端开发 索引
            JavaScript学习第二章--字符串
            本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
            20 2
            |
            20天前
            |
            存储 JavaScript 前端开发
            JavaScript学习第一章
            本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
            46 1
            |
            2月前
            |
            自然语言处理 前端开发 JavaScript
            🛠️ JavaScript数组操作指南:20个精通必备技巧🚀
            本文详细介绍了 JavaScript 中的 20 个高效数组操作技巧,涵盖了从基本的添加、移除元素,到数组转换和去重等高级操作。强调了不可变性的重要性,提供了清晰的代码示例,帮助开发者编写更整洁和高效的代码。无论是新手还是经验丰富的开发者,这些技巧都将显著提升您的编码能力,使您在项目中更具竞争力。
            34 2
            |
            2月前
            |
            JavaScript 前端开发 测试技术
            JS都有哪些操作数组的方法
            JS都有哪些操作数组的方法
            28 3
            |
            2月前
            |
            缓存 JavaScript 前端开发
            JavaScript中数组、对象等循环遍历的常用方法介绍(二)
            JavaScript中数组、对象等循环遍历的常用方法介绍(二)
            43 1
            |
            2月前
            |
            JavaScript
            js学习--商品列表商品详情
            js学习--商品列表商品详情
            20 2
            |
            2月前
            |
            JavaScript
            js学习--九宫格抽奖
            js学习--九宫格抽奖
            19 2
            |
            2月前
            |
            JavaScript
            js学习--开屏弹窗
            js学习--开屏弹窗
            37 1
            |
            2月前
            |
            JavaScript
            js学习--抽奖
            js学习--抽奖
            17 1