认识数组数据类型 - Array

认识数组数据类型 - Array

解释

1.是一个 JS 内的数据类型, 是一个复杂数据类型

2.也是一个 “盒子”, 用来存储数据的盒子

3.数组内存储的数据是按照 “序号” 排列的, 有序的数据集合

4.序号: 叫做 索引 或者 下标, 从 0 开始, 依次 +1

创建数组数据类型

1. 字面量方式创建

(1) 创建空数组: var arr = []

​ ( 2 )创建一个带有数据的数组: var arr = [ 数据1, 数据2, 数据3, … ]

// 空数组
     var arr = []
     console.log(arr)
    // 带有数据的数组
     var arr = [ 100, 200, 300, true, 'hello', { name: 'Jack' }, function () {} ]
     console.log(arr)

2. 内置构造函数方式创建

​ (1) 创建空数组: var arr = new Array()

​ (2) 创建一个带有数据的数组: var arr = new Array( 数据1, 数据2, 数据3, … )

​ (3) 创建指定长度的数组: var arr = new Array(数字)

// 空数组
     var arr = new Array()
     console.log(arr)
    // 带有数据的数组
     var arr = new Array( 100, 200, 300, true, 'hello', { name: 'Jack' }, function () {} )
     console.log(arr)
    // 指定长度的数组
    // 这里的 10 指的是数组的长度
    // 因为你只是指定了长度, 没有指定每一个位置的数据, 那么使用 empty 填充
    var arr = new Array(10)
    console.log(arr)

数组和对象的区别

​ 1. 一般来说, 数组存储的都是有规律的数据

​ 数组内的所有数据都是一个数据类型

​ 2. 一般来说, 对象存储的都是无规律的数据

​ 一般用来描述一个事物或者内容

数组的基本操作

length 属性

​ (1)每一个数组带有一个 length 属性

​ (2)是一个读写的属性

​ (3)读(获取)

​ <1> 语法: 数组名.length

​ <2>得到: 该数组内有多少个数据, 是一个 Number 类型

​ (4) 写(设置)

​ <1> 语法: 数组名.length = 数字

​ <2> 作用: 设置数组的长度

​ 你设置的数字比原先 length 小: ** 从数组的末尾开始删除数据 **

​ 你设置的数字和原先 length 一样: 写了白写

​ 你设置的数字比原先 length 大: ** 空出来的位置使用 empty 补齐 **

索引 属性

​ (1) 每个数据都可以依靠索引属性操作数据中的数据

​ (2)是一个读写的属性

​ (3)读(获取)

​ 语法: 数组名[索引]

​ 得到: 数组该索引位置的数据

​ 如果有该索引位置, 就是该索引位置的数据

​ 如果没有该索引位置, 那么就是 undefined

​ (4) 写(设置)

​ 语法: 数组名[索引] = 值

​ 作用: 给数组该索引位置进行赋值

​ 1.你设置的索引是数组中本身存储在的: 修改数组中某一个索引位置的数据

​ 2.你设置的索引刚好和 length 一样:

​ (1) 数组最后一位的索引一定是 length - 1

​ (2) 你设置的是 length, 就相对于在现有基础上追加一个数据

​ 3. 你设置的索引比 length 大:

​ (1) 会设置到指定索引位置

​ (2) 中间空出来的会用 empty 补齐

​ (3) 为了保证数组最后一位的索引一定是 length - 1

数组的遍历

​ 1. 因为数组的数据排列是按照索引排列的, 一组有规律的数字

​ 2. 循环刚好可以给我们提供一组有规律的数字

​ 3. 我们就可以使用循环来遍历数组, 使用循环控制变量充当数组的索引

实例

// 准备一个数组
    var arr = [ 100, 200, 300, 400, 500 ]
    console.log(arr)

    // 1. length 属性
     console.log(arr.length)

    // 1-2. length 属性设置
     arr.length = 10
     console.log('设置长度之后 : ', arr)


    // 2. 索引属性
     console.log(arr[2])
     console.log(arr[100])

    // 2-2. 索引属性设置
    // 本身有这个索引, 就是替换
     arr[2] = '新来的'
     console.log('索引属性设置之后 : ', arr)
    // 刚好和 length 一样, 就是追加
     arr[arr.length] = '新来的'
     console.log('索引属性设置之后 : ', arr)
    // 比 length 大, 中间位置使用 empty 补齐
     arr[100] = '新来的'
     console.log('索引属性设置之后 : ', arr)

    // 3. 数组 遍历
    // 开始: 0
    // 条件: <= length - 1
    // 步长: +1
    for (var i = 0; i < arr.length; i++) {
      // 在循环内, i 刚好和 arr 的每一个索引配套
       console.log(i)
      console.log(arr[i])
    }

案例

案例1:找到数组中的最大值

// 准备一个数组
     var arr = [ 10, 20, 12, 34, 21, 6, -3, 7 ]
     console.log(arr)

    // 步骤1: 假设一个数字是数组中的最大值, 假设那个数字 ?
    // 假设数组中的 [0] 数据是数组中的最大值
     var max = arr[0]
    // 步骤2: 循环遍历数组, 依次与 max 进行比较
    //       如果大于 max, 就进行替换
     for (var i = 1; i < arr.length; i++) {
       if (arr[i] > max) {
    //     // 进行替换
         max = arr[i]
       }
     }
    // 循环结束以后, max 就是数组中最大的那个数字
     console.log(max)

案例2:找到数组中的最大值的索引

   var arr = [ 10, 20, 12, 34, 21, 6, -3, 7 ]
     console.log(arr)
    // 步骤1: 假设一个索引位置的数字是数组中的最大值, 假设 [0]
     var maxIndex = 0
    // 步骤2: 循环遍历数组, 依次与 arr[maxIndex] 进行比较
     for (var i = 1; i < arr.length; i++) {
    //   // 进行比较
       if (arr[i] > arr[maxIndex]) {
    //     // 进行替换的时候, 替换索引
         maxIndex = i
       }
     }
    // 循环结束, maxIndex 就是数组内最大数据的索引
     console.log(maxIndex, arr[maxIndex])

案例3:制作一个数组

要求:数组长度是30,数组内的数据分别是从2开始的所有偶数

方案1

 1. 我们可以定义一个指定长度的数组
      2. 直接开始遍历数组, 遍历的过程中能拿到每一个索引
      3. 找到 索引 和 每一个数字之间的关系
        => 0     2
        => 1     4
        => 2     6
        => 3     8
        => 4     10
        => ...
        => x     (x + 1) * 2
    
    // 步骤1:
     var arr = new Array(30)
     console.log(arr)
    // // 步骤2: 遍历
     for (var i = 0; i < arr.length; i++) {
    //   // 给每一个 i 的位置进行赋值
       arr[i] = (i + 1) * 2
     }
    // // 循环完毕
     console.log(arr)

方案2

/*
      1. 准备一个空数组
      2. 循环遍历拿到 2 ~ 60 的数字
      3. 把每一个数字依次追加到数组内
    */

    // 步骤1:
     var arr = []
     console.log(arr)
    // // 步骤2: 循环拿到数字
     for (var i = 2; i <= 60; i += 2) {
        console.log(i)
    //   // 每次追加到数组内即可
       arr[arr.length] = i
     }
    // // 循环结束以后
     console.log(arr)

方案4

/*
      1. 准备一个空数组
      2. 使用 while 循环依次追加
        => 判断条件 length < 30
      3. 随着循环逐个追加数据
    */

    // 步骤1: 准备一个空数组
     var arr = []
     console.log(arr)

    // // 步骤2: 使用 while 循环来根据 length 决定是否循环
     while (arr.length < 30) {
    //   // 这里的代码执行, 表示 arr.length 不够 30
       arr[arr.length] = (arr.length + 1) * 2
     }

    // // 循环结束以后
     console.log(arr)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值