本文是金旭亮老师网易云课堂的课程笔记,记录下来,以供备忘。

数组是“多态数组" ,啥都可以放

         //JavaScript中的多态数组
var arr = ["one", 2, true,
function (a, b) { return a + b; },
[1,2,3]
];

数组是一个对象,拥有自己的属性与方法

        //数组是一个对象
console.info(arr);
console.info(arr.length);

访问与写入

访问

         //数组元素通过下标访问
console.info(arr[0]); //one
//调用放在数组中的函数
console.info(arr[3](100, 200));//
//访问放在数组中数组
console.info(arr[arr.length - 1].length);//
//当读取没有内容的位置时,返回undefined
console.info(arr[100]);//undefined

写入:

         var arr2 = [];
//向空数组赋值,将导致数组中添加一个元素
arr2[0] = "Hello";
//读取新加入的元素
console.info(arr2[0].toUpperCase());
//跳着赋值,将导致数组自动地增长
arr2[3] = 3;
console.info(arr2.length);//
console.info(arr2);//["Hello", 3: 3]
//中间的值为undefined
console.info(arr2[1]); //undefined

在尾部追加:

         //自动在尾部追加元素
var arr3 = [];
for (var i = 0; i < 5; i++) {
arr3[arr3.length] = i;
}
//数组内容为:[0, 1, 2, 3, 4]
console.info(arr3);

数组常用方法:

concat  直接连接两个数组的元素。

             var left = [1, 2], right = [3, 4];
console.info(left.concat(right)); //[1,2,3,4]

join  数组中每个元素通过分隔符相连.

         var words = ["锤子", "剪刀", "布"];
var result = words.join('<-->');
//锤子<-->剪刀<-->布
console.info(result);

数组当堆栈:

                    push 入栈
                     pop   出栈
            var m_arr = ['a', 'b', 'c'];
m_arr.push('d');
console.info(m_arr); //["a","b","c","d"]
m_arr.pop();
console.info(m_arr); //["a","b","c"]

开头操作数组元素:

unshift  开头插入

                    shift     删除开头
         var arr = ["a", "b", "c"];
arr.unshift("99");
console.info(arr); //["99", "a", "b", "c"]
var shifted = arr.shift();
console.info(shift); //
console.info(arr); //["a", "b", "c"]

截取:

                    使用slice提取子数组
                    按[起始索引值,结束索引值) 来截取:
             var bigArr = ["a", "b", "c", "d", "e", "f"];
var subArr = bigArr.slice(1, 4);
console.info(subArr); //"b","c","d"

删除元素:

splice  从第n个索引值开始删除m个

              var arr = ["a", "b", "c", "d", "e", "f"];
arr.splice(2, 3); //索引值第2个开始删除3个
console.info(arr); // a, b, f

delete  虽删除但下标犹在.

          var arr = ["a", "b", "c", "d", "e", "f"];
delete arr[2];
console.info(arr); //["a", "b", 3: "d", 4: "e", 5: "f"]
console.info(arr[2]); //undefined

splice有多于2个参数时,就变成删除后再插入元素

             var arr = ["a", "b", "c", "d", "e", "f"];
arr.splice(2, 3,"one","two"); //索引值第2个开始删除3个后再插入 one , two
console.info(arr); // a,b,one,two,f

数组排序:

排序与反转:

             var data = [];
for (i=0 ; i<=6; i++) {
data[data.length] = Math.floor(Math.random() * 100);
}
console.info(data.sort()); //升序
console.info(data.reverse()); //反转

对象数组也排序:

  • 自定义排序的关键在于设计好排序比较函数。
  • 排序是在原数组上进行的.
   //定义一个Person构造函数
function Person(name, age) {
this.name = name;
this.age = age;
};
//定义一个函数,用于输出Person集合中的数据
function printPeople(arr) {
for (var i = 0; i < arr.length; i++) {
console.info(arr[i].name + "有" + arr[i].age + "岁");
}
};
//使用forEach方法,以回调方式遍历处理数组中的元素
function printPeople2(arr) {
//forEach回调函数参数说明:
//value:代表数组中的单个元素
//index:代表数组中此元素对应的索引
//traversedObject:引用被遍历的数组
arr.forEach(function (value, index, traversedObject) {
console.info(value.name + "有" + value.age + "岁");
});
};
//生成测试数据
var people = [];
for (var i = 1; i < 5; i++) {
var age = Math.floor(Math.random() * 100);
people[people.length] = new Person('用户' + i, age);
}
console.info("原始数组:");
printPeople(people);
//自定义排序
//比较函数具有两个参数 a 和 b,其返回值如下:
//若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
//若 a 等于 b,则返回 0。a,b视为相等
//若 a 大于 b,则返回一个大于 0 的值。b应该排在a的后面
people.sort(function (p1, p2) {
if (p1.age > p2.age) return 1;
if (p1.age < p2.age) return -1;
return 0;
});
console.info("排序后的数组:");
printPeople2(people);

JavaScript我学之七数组的更多相关文章

  1. JavaScript jQuery 中定义数组与操作及jquery数组操作

    首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...

  2. JavaScript中常见的数组操作函数及用法

    JavaScript中常见的数组操作函数及用法 昨天写了个帖子,汇总了下常见的JavaScript中的字符串操作函数及用法.今天正好有时间,也去把JavaScript中常见的数组操作函数及用法总结一下 ...

  3. JavaScript面向对象程序设计:数组

    或许你会奇怪,面向对象的程序设计为什么从数组开始讲起?这是因为……其间的种种关系吧……嘿嘿,这里先卖个关子,先来看看我们熟悉的数组在JavaScript里面是什么样子的.   1. 创建数组   在J ...

  4. javascript中的稀疏数组(sparse array)和密集数组

    学习underscore.js数组相关API的时候.遇到了sparse array这个东西,曾经没有接触过. 这里学习下什么是稀疏数组和密集数组. 什么是密集数组呢?在java和C语言中,数组是一片连 ...

  5. Javascript Jquery 中的数组定义与操作_子木玲_新浪博客

    body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...

  6. javaScript(8)---对象和数组

    javaScript(8)---对象和数组 学习要点: 1.Object类型 2.Array类型 3.对象中的方法 什么是对象,其实就是一种类型,即引用类型.而对象的值就是引用类型的实例.在ECMAS ...

  7. 同事问如何判断同花顺,我用javascript的二维数组写了个简易demo

    有个前同事在群里问如何判断是否为同花顺我用javascript的二维数组写了个简易demo. <!DOCTYPE html> <html> <body> <s ...

  8. JSON.stringify()方法是将一个javascript值(对象或者数组)转换成为一个JSON字符串;JSON.parse()解析JSON字符串,构造由字符串描述的javascript值或对象

    JSON.stringify()方法是将一个javascript值(对象或者数组)转换成为一个JSON字符串:JSON.parse()解析JSON字符串,构造由字符串描述的javascript值或对象

  9. javaScript遍历对象、数组总结(转载)

    javaScript遍历对象.数组总结  转载来源 https://www.cnblogs.com/chenyablog/p/6477866.html 在日常工作过程中,我们对于javaScript遍 ...

随机推荐

  1. NPOI “发现 中的部分内容有问题,是否要恢复此工作薄的内容?如果信任此工作薄的来源。。。”的问题的解决方法

    网上说的方法是调整Sheet可见和顺序:https://blog.csdn.net/hulihui/article/details/21196951 stackoverflow给出的解释是:单元格存储 ...

  2. Socket通信例子

    Server端 using System; using System.Collections.Generic; using System.ComponentModel; using System.Da ...

  3. [模板] 笛卡尔树 && RMQ

    话说我noip之前为什么要学这种东西... 简介 笛卡尔树(Cartesian Tree) 是一种二叉树, 且同时具有以下两种性质: 父亲节点的值大于/小于子节点的值; 中序遍历的结果为原序列. 笛卡 ...

  4. 【LR9】【LOJ561】CommonAnts 的调和数 数论 筛法

    题目大意 有一个长度为 \(n\) 的序列. 有 \(m\) 次修改,每次给你 \(x,y\),令 \(\forall 1\leq i\leq \lfloor\frac{n}{x}\rfloor,a_ ...

  5. 【APIO2016】【UOJ205】【LOJ2568】烟花表演 可合并堆

    题目大意 有一棵树,每条边都有一个边权,现在你要修改边权,使得修改后根到所有叶子的距离相等. 要求所有边权非负. 修改的代价为\(\lvert\)每条边修改前的边权\(-\)修改后的边权\(\rver ...

  6. Matlab常用函数集锦

    ndims(A)返回A的维数size(A)返回A各个维的最大元素个数length(A)返回max(size(A))[m,n]=size(A)如果A是二维数组,返回行数和列数nnz(A)返回A中非0元素 ...

  7. 第四十篇-private,public,protected的区别

    1.public: public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private: private表示私有,私有的意思就是除了class自己之外,任何人都不可 ...

  8. Memcached操作

    标准协议和字段 Memcached的标准协议字段包含以下部分: 键,key,任意字符,最大250字节,不能有空格和换行 标志位,32比特,不能为0 超时时间,单位是秒,0代表永不超时,最长30天,30 ...

  9. 记一次504 Gateway Time-out

    使用curl请求是超时,查了下资料原来是端口被占用,造成了死锁,记录下 首先要知道为什么会出现死锁? 在我们访问页面的时候这个端口进程就已经被使用,当我们再在页面中curl请求其他页面因为没有其他的端 ...

  10. vmware(1):vmware中的bridge、nat、host-only的区别

    VMWare提供了三种工作模式,它们是bridged(桥接模式).NAT(网络地址转换模式)和host-only(主机模式) bridged(桥接模式) 在这种模式下,VMWare虚拟出来的操作系统就 ...