数组

作者: 致自己_cb38 | 来源:发表于2018-09-26 21:46 被阅读0次

1.数组的概念

  • 定义:用于保存一组数据的集合。
  • 数组的定义格式: 中括号或者new定义,里面每一个元素结束的时候使用一个逗号隔开,最后一个元素可以不使用逗号结尾。

2.数组的申明

  • var a = [];
  • var a = new Array();

3. instanceof 查看某个变量是否是某个数据类型的实例。

4.数组保存数据的格式

  • 严格意义上来说数组可以保存任意格式的数据。
  • 如果数组中保存的还是一个数组,那么这个数组叫做多维数组。
    var a =[
    [[1,2,3],2,3],
    [4,3,2],
    [8,2,7]
    ];

5.数组的键

  • 数组的每一个元素都是由键与值组成。
    [1,2,3,4,5];
    [
    0 => 1,
    1 => 2,
    2 => 3,
    3 => 4,
    4 => 5,
    ]
    ['a','b','c']
    [
    0 => 'a',
    1 => 'b',
    2 => 'c',
    ]
  • 数组的键是从0 开始的,是一个递增的数值队列。
  • Object.keys() 获取某一个数组所有的键。返回的也是一个数组,这个数组是由原数组的键组成的。当然这个数组也有自己的键。
  • 数组所有的键都是字符串格式的,只是看起来有点像数字格式,这个是和对象是一样的。对象所有的键也都是字符串格式的。
  • 在获取数组的某一个值的时候,键名首先会转化为整形,然后整形转化字符串。如果是带有小数点后面数字的小数就不行了。

5.数组的访问形式

  • 对象访问形式
    oDiv.style.display
    oDiv['style']['display']
  • 数组访问形式
    arr[数字]
    arr[变量]
  • 数组也支持存放不是数字键的元素,但是这个元素是按照对象的格式存放的,不计算在数组的元素个数中。可以使用对象的方式获取,也可以使用数组的方式获取。
    arr['name'] = 'zhangsan';

6. delete 删除一个对象的属性。

也能够删除数组的元素,但是删除之后元素的值删除了,但是数组的长度不会发生变化。也就是length不会改变。

7. length

  • 数组中最重要的一个属性,表示数组中元素的个数。这个length是动态变化的。数组元素增加的时候,length会自动变大,元素减少的时候,length会自动的减少。如果手动设置length,那么数组也会发生变化。
  • 数组的键是使用32为2进制来保存的,所有最大值是2^32-1;
    也就是数组最多只能保存2^32-1个值。
  • 数组的元素可以是不连续的,但是length总是比最大的键名大1.
    没有保存数据的位置是空位。

8.in运算符

判断某一个{键}是不是在数组中,返回的是一个bool值。也能判断对象是否具有某个属性。
eg:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<script>
var arr = [1,3,5,89];
console.log(2 in arr); //true 判断是键
console.log(89 in arr); //false
//能不能判断对象的属性在不在对象里面
var zhangsan = {
    "age":"14",
    "height":"141",
    "weight":"200",
};
console.log('age' in zhangsan); //true
console.log('age1' in zhangsan); //false
</script>
</body>
</html>

9.for... in

  • 遍历数组。类似于while循环以及for循环。但是比这俩智能一点,会跳过空位。
for(var j in arr){
    console.log(arr[j]);
}
  • for..in 遍历会将数组中不标准的键名和值也会遍历出来,而for循环以及while不会。

10.forEach 遍历数组

arr.forEach(function(){
    
});

11.数组中的空位

  • 数组中间的空位是计算在length里面的,但是里面没有值,获取的时候是undefined。
    var arr = [1,2,,,,,4];
  • 数组结尾的空位是不生效的,所以可以省略最后的一个逗号。

undefined 与空位的区别:

  • 获取内容的时候都是undefined。
  • 真实空位在for……in循环遍历的时候会自动跳过,而真实存储undefined的位置不会跳过。
    eg:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<script>
var arr = [1,2,3,,,,,5,6];
console.log(arr[5]); //undefined
for(var i in arr){
    console.log(i); // 键名01278
}
var arr1 = [1,2,3,undefined,undefined,3,4];
console.log(arr1[3]); //undefined
for(var j in arr1){
    console.log(j)  //0123456
}
</script>
</body>
</html>

12. 类数组对象

类似于数组的对象 。 具有length属性,这个属性表示的变量内部的元素的个数。但是这个length不会动态变化。
eg:

  • arguments: 参数对象
  • 字符串
  • 绝多数的DOM集合。oDiv

13.数组函数

  • 压栈函数
    • push 推 向数组中添加一个元素,添加到数组的最后
      pop 弹出 从数组中弹出一个元素,从最后删除一个元素。

    • unshift: 向数组中添加一个元素,添加到数组开头
      shift: 从数组中删除一个元素,从数组的开头删除。

    • splice: 从数组中删除元素。

      • splice(start,num);从start(键名)位置开始,删除num个元素。
      • splice(start,num,....);从start位置开始,删除num个元素。然后将后面的所有的参数作为元素添加带这个删除元素的位置。如果num是0,那么在start的位置开始插入元素。
        eg:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<script>
var arr = [1,3,5,7];
arr.splice(1,0,100,200,11);
console.log(arr); //1 100 200 11 3 5 7
</script>
</body>
</html>
  • slice:数组截取,不会改变元素的数组,只是将截取出来的数据作为返回值单独返回。
    slice(start,end-1)返回的是start开始,到end-1的数组元素的集合,返回的也是一个数组。
    eg:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<script>
var arr = [1,2,3,4,5];
var a = arr.slice(1,4); //2,3,4
console.log(arr);
console.log(a);
</script>
</body>
</html>
  • join:将数组转化为字符串,默认是使用逗号连接。
    join(连接符):将数组元素使用连接符连接起来组成字符串。

  • concat:合并数组。
    数组1.concat(数组2); 返回的是一个合并后的数组。并不会改变原来的数组。
    eg:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<script>
var arr0 = ['I',
'L','o','v','e','Y','o','u'];
var you = [5,2,0,1,3,1,4];
var arr = arr0.concat(you);
console.log(arr); //'I','L','o','v','e','Y','o','u',5,2,0,1,3,1,4
</script>
</body>
</html>
  • reverse:数组翻转;会改变原来的数组。
    arr.reverse();

14.冒泡排序

eg:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title></title>
    <style>

    </style>
</head>
<body>
    <script>
        var arr = [2,4,3,8,6,9,10];
        // 最后一个数不用比较
        for (var i = 0; i < arr.length-1; i++) {
            // 外面循环1次,里面循环length-i次,当外面循环第一次时,
           //第一个数与其他每个数进行比较,防止死循环
            for (var j = 0; j < arr.length-i; j++) {
                // 类似于有3个水缸进行替换
                if (arr[j+1] > arr[j]) {
                    var a = arr[j+1];
                    arr[j+1] = arr[j];
                    arr[j] = a;
                }
            }
        }
        console.log(arr);
    </script>
</body>
</html>

相关文章

  • 数组

    数组数组数组数组数组数组数组数组数组

  • JavaScript - 5.数组<增删改查>

    数组 Array 数组 - 增 数组 - 删 / 改 数组 - 查 数组 - 自动 toString() 数组 -...

  • PHP数组使用

    数组定义 数组增、删、改 数组查询 数组排序 数组合并、分割 数组比较、去重复 数组长度 数组遍历 数组转换 其他...

  • 》》》PHP初入---(三)

    数组定义 1.索引数组:数组下标是整型的 声明数组: 访问数组: count(数组)--获取数组长度 查看数组所有...

  • JavaScript中数组的常用操作

    数组的遍历 数组的映射 数组的简化 数组的连接 获取数组的片段 数组的拷贝 查找数组 数组去重

  • JavaSE之数组

    六、数组 目录:数组概述、数组声明创建、数组使用、多维数组、Array类、稀疏数组 1.什么是数组 数组的定义:数...

  • Shell数组、关联数组

    数组 定义数组 获取数组 关联数组 定义关联数组 获取关联数组

  • 学习Java第五天

    数组是多个数据的集合 数组的语法 数组元素类型【】 数组名; 多维数组: 数组元素类型【】【】 数组名; 多维数组...

  • php基础精粹

    PHP php数组 php数组之索引数组初始化 PHP数组之索引数组赋值 PHP数组之访问索引数组内容 PHP数组...

  • C语言的惯用集

    数组部分 数组部分 清空数组a 把数据读进数组a 对数组a求和

网友评论

      本文标题:数组

      本文链接:https://www.haomeiwen.com/subject/jkyjoftx.html