创建数组

  var a=[1,2,3,4]

  var arr=new Array()

  var arr=new Array(10);//创建长度为10的数组

    var arr=new Array(1,2,3,4,5,6);//创建数组

arr.length==6;

数组的删除delete  var a=[1,2,3];

  delete a[0];

  1 in a   //false,

  a.length //3,delete操作并不会影响数组的长度

数组的遍历

  for/in    forEach

    var a=[1,2,3];

    var b=0;

    a.forEach(function(x){

      b+=x;//相加

    })

数组的方法

  Array.jion();//将所有的元素转换为字符串并连接在一起,默认逗号连接,有一个参数,可以修改连接的样式

  Array.reverse();//将数组反向排序

  Array.sort();//将数组排序后并返回排序后的数组,如果不带参数,默认字母表顺序,有参数根据回调函数的返回值来确认顺序

    var a=[33,4,1111,222];

    a.sort();//1111,222,33,4;

    a.sort(function(a,b){

      return a-b;//4,33,222,1111

    });

    a.sort(function(){

      return b-a;//1111,222,33,4

    })

  Array.concat();//连接数组

    var a=[1,2,3];

    a.concat(4,5);//[1,2,3,4,5]

    a.concat([4,5]);//[1,2,3,4,5]

    a.concat([4,5],[6,7]);//[1,2,3,4,5,6,7]

    a.concat([4,[5,[6,7]);//[1,2,3,4,5,[6,7]]

  Array.slice();返回指定数组的片段

    var a=[1,2,3,4,5];

    a.slice(0,3);//[1,2,3,4];

    a.slice(3);//[4,5];

    a.slice(1,-1);//[2,3,4];

    a.slice(-3,-2);//[3]

  Array.splice();splice()会修改数组,第一个参数起始点,第二个参数删除的个数,之后的参数是插入的元素,插入元素的起始点就是第一个参数,注意,插入的数组是数组本身,不是里面的元素

  Array.push()和Array.pop();push在尾部添加元素,pop在尾部删除元素,修改原来的数组

  Array.unshift()和Array.shift();unshift在头部添加元素,shift在头部删除元素,修改原来的数组

  Array.toString()和Array.toLocalString();转换为字符串

ES5中数组的方法

  forEach()方法

  map()方法

    var a=[1,2,3];

    b=a.map(function(x){

      return x*x;//b是[1,4,9]

    })

  filter()

    var a=[5,4,3,2,1];

    b=a.filter(function(x){

      return x<3;//[2,1]

    })

    var a=[5,4,3,2,1];

    b=a.filter(function(x,i){

      return i%2==0;//[5,3,1],i是filter的第二个参数,他表示的是数组的下标,还有第三个参数当期元素属于数组的对象

    })

  every()和some();是数组的逻辑判断

    var a=[5,4,3,2,1];

    b=a.every(function(x){

      return x<10;//true;

    })

     var a=[5,4,3,2,1];

    b=a.some(function(x){

      return x%2===0;//false;

    })

  reduce()和reduceRight()

    var a=[5,4,3,2,1];

    b=a.reduce(function(x,y){

      return x+y;//数组求和

    },0)

    b=a.reduce(function(x,y){

      return x*y;//数组求积

    },1)

    b=a.reduce(function(x,y){

      return x>y?x:y;//求最小值

    },1)

    reduce()//两各参数,第一个参数执行函数,第二个参数可选初始值,第一次执行函数时,初始值作为函数的第一个参数,以后执行函数返回的值作为函数第一个参数

    reduceRight()和reduce()一样,执行从最后一个元素开始执行

  indexOf()和lastindexOf;搜索数组的指定的元素,如果找到返回下标,如果没找到返回-1

数组的类型

  Array.isArray([]);//true

  Array.isArray([]);//false

    

数组 javaScript权威指南笔记的更多相关文章

  1. javascript权威指南笔记

    最近每天工作之余看下js的细节部分,时间不是很多,所以看的进度也不会太快,写个博客监督自己每天都看下. 以前不知道的细节或者以前知道但是没注意过的地方都会记录下来,所以适合有一定基础的,不适合零基础新 ...

  2. javascript权威指南笔记--javascript语言核心(四)

    对象: 通过引用(而非值)来操作对象: var obj = {"x":1,"y":2}; var copyObj = obj; copyObj.x = 5; c ...

  3. javascript权威指南笔记--javascript语言核心(三)

    1.var用来声明一个或多个变量.全局变量是全局对象的属性,它无法通过delete删除. 如果var语句中的变量没有指定初始化表达式,那么这个变量的初始值为undefined. 变量声明语句会被提前到 ...

  4. javascript权威指南笔记--javascript语言核心(二)

    1.函数作用域:在函数内声明的所有变量在函数体内始终是可见的.这意味着在变量声明之前甚至已经可用. *“声明提前”:javascript函数里声明的所有变量(但不涉及赋值)都被提前至函数的顶部. fu ...

  5. javascript权威指南笔记--javascript语言核心(一)

    1.javascript的数据类型分为两类:原始类型和对象类型. 原始类型包括字符串.数字.布尔值.null.undefined. 对象是属性的集合,每个对象都由“名/值”对构成.数组和函数是特殊的对 ...

  6. 1.语言概述-JavaScript权威指南笔记

    上周三的时候交给老板目前的项目第一个迭代回顾会的总结.原本是以综述性的表述方式写的,交给他之后表示程序员不要长篇大论.总结要分为优点缺点期望等等块,每块列出条目,简明扼要的表达出来.这里也用这种风格. ...

  7. [JavaScript权威指南 [笔记]

    对象的比较均是引用的比较.(不可变的原始值和可变的对象引用)this返回调用这个方法的对象通过x!==x来判断x是否为NaNvar max = max_width || preferences.max ...

  8. javascript权威指南笔记[1-5]

    1.javaScript的数据类型分为两类:原始类型和对象类型: 2.javaScript中除了数字,字符串,布尔值,null,undefined之外就是对象了: 3.对象(object)是属性(pr ...

  9. 2.语言概述-JavaScript权威指南笔记

    上周三的时候交给老板目前的项目第一个迭代回顾会的总结.原本是以综述性的表述方式写的,交给他之后表示程序员不要长篇大论.总结要分为优点缺点期望等等块,每块列出条目,简明扼要的表达出来.这里也用这种风格. ...

随机推荐

  1. 实现后门程序以及相应的rootkits,实现对后门程序的隐藏

    iptables的一些命令: a.    a) 使用规则实现外网不能访问本机,但是本机主动发起的连接正常进行. sudo iptables –A INPUT -p tcp —tcp —syn -j D ...

  2. $anchorScroll angular锚点服务

    angular锚点服务 $anchorScroll 普通的html页面中,我们会通过在url后面添加#elementId的方式,将页面显示定位到某个元素上,也就是所谓的锚点. 但是在angular应用 ...

  3. 菜鸟vimer成长记——第2.2章、visual模式

    vi是没有可视模式的.然而大多数编辑软件都都是有可视模式.所以我猜测vim是几乎迫于无奈才有了visual模式. 个人建议,能不用就不用.这样能直接在头脑里处理好文本,锻炼文本处理能力,同时能转变过来 ...

  4. 工作之路---记录LZ如何在两年半的时间内升为PM

    引言 之前的伪PM纠结之路已经渐渐结束,LZ也终于正式爬上了PM的位置,对于LZ来说,这个时间比LZ预计的早来了两年半.说起来,两年半的速度已经算是比较快了,但这之中的努力唯有LZ一人知晓.写这篇文章 ...

  5. jenkins使用时出现的问题!

      从安装到日常使用中遇到过的问题和解决方法:   背景/问题:安装时是跳过安装插件过程的,安装好后,我发现里面啥也做不了,连个git的插件都无法下载. 方法:在jenkins的主界面,打开系统管理= ...

  6. Laya LoaderManager小记

    LoaderManager 类用于用于批量加载资源.此类是单例,不要手动实例化此类,请通过Laya.loader访问.全部队列加载完成,会派发 Event.COMPLETE 事件:如果队列中任意一个加 ...

  7. 通过扩展方法简化UnityAPI调用

    通过扩展方法简化UnityAPI调用 扩展方法unity apiapi简化 通过扩展方法简化UnityAPI调用 能省一秒是一秒,时间就是金钱,没人愿意把时间花在冗长的coding上

  8. Linux系统下搭建FTP/SFTP服务器

    传输文件经常使用ftp和sftp服务器.Windows下有多种可视化工具,使用快捷.Linux经常需要自行搭建这两种服务器,当然搭建熟练的话,会更加快捷. 1.检查Linux系统是否安装了vsftp和 ...

  9. 关于inherit的笔记

    1. inherit是动态的 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  10. java学习de路线建议

    我想谈一谈我的一些关于网页学习的小感悟吧.之所以是写这个的原因完全是想告诉现在还处在网页学习的初始阶段的同学一些我学习走过的弯路,但我说的也仅是我个人的理解,毕竟我只能是JavaWeb开发的新手,所以 ...