【1】、数组字面量

  var empty=[];
  var num=[
    'zero','one','two','three','four','five','six','seven','eight','nine'
  ];

  document.write("<br/>"+empty[0]);undefined

  document.write("<br/>"+num[0]);//zero

  document.write("<br/>"+num.length+"<br/>"+empty.length);10,0

  var misc=['string',true,[0,1],{object:true},NaN,null,undefined];//数组中可以是任意混合类型的值
  document.write("<br/>"+misc.length);//7

【2】、长度

  var myArr=[];
  myArr.length;
  document.write("<br/>"+myArr.length);
  myArr[9999]=true;
  document.write("<br/>"+myArr.length);//10000 数组最大整数属性名+1,并不一定等于数组中的属性个数

  num.length=3;
  num[num.length]='shi';
  num.push("go");//添加到数组中
  document.write("<br/>"+num);//zero,one,two,shi,go

【3】、删除

  delete num[2];
  document.write("<br/>"+num);//zero,one,,shi,go

  num.splice(2,2);//第一个参数是数组中的序号也就是下标,从0开始数,第二个参数就是要删除的元素的个数
  document.write("<br/>"+num);//zero,one,go  ,对于大型的数组,效率不高,因为被删除的属性后面的每个属性都要被溢出,并且以一个新的键值重新插入

【4】、枚举:就是能够通过for 循环遍历出来

【5】、混淆的地方

  数组跟对象的使用尝尝会弄混,所以,写了一个判断是否为数组的方法:

  var is_array=function(value){
    return value&&
    typeof value=='object'&&
    typeof value.length=='number'&&
    typeof value.splice=='function'&&
    !(value.propertyIsEnumerable('length')); //length能够通过for in循环遍历出来,对于所有数组来说,返回的都是false
  };

【6】、方法

  Array.method("reduce",function(f,value){
    var i;
    for(i=0;i<this.length;i++)
    {
      value=f(this[i],value);//value是个临时变量,用来临时保存最后相加的值,然后在跟后面一个值相加
    }
    return value;
  });

  var data=[4,8,15,16,23,42];
  var addNum=function(a,b){
    return a+b;
  };
  var mult=function(a,b){
    return a*b;
  };

  var sum=data.reduce(add,0);

  var product=data.reduce(mult,1);  document.write("<br/>相加:"+sum+"<br/>相乘:"+product);//相加:108 相乘:7418880

  
  data.total=function(){ //数组是对象,所以,可以给一个单独的数组添加方法
    return this.reduce(add,0);
  };

  document.write("<br/>"+data.total());//108

【7】、维度

  //一维数组
  Array.dim=function(a,b){
    var c=[],i;
    for(i=0;i<a;i++){
      a[i]=b;
    }
  };

  var arr1=Array.dim(10,0);

  //二维数组或者是数组的数组
  var maxrix=[
    [0,1,2],
    [3,4,5],
    [6,7,8]
  ];
  document.write("<br/>"+maxrix[2][2]);//8

  Array.maxrid=function(m,n,inital){
    var a,i,j,mat=[];
    for(i=0;i<m;i++)
    {
      a=[];
      for(j=0;j<n;j++){
        a[j]=0;
      }
      mat[i]=a;
    }
    return mat;
  };

  var myMaxrix=Array.maxrid(4,4,0);
  document.write("<br/>"+myMaxrix[3][3]);//0

  Array.identity=function(n){//恒等矩形
  var i,mat=Array.maxrid(n,n,0);
    for(i=0;i<n;i++){
      mat[i][i]=2;
    }
    return mat;
  };

  document.write("<br/>"+Array.identity(4)[3][3]);//2

  

  

《javascript语言精粹》——第6章数组的更多相关文章

  1. 《JavaScript语言精粹》第二章-语法 简单笔记

    注释 JavaScript提供两种注释: /* */包围的块注释及//开头的行注释. 注释应该被优先用来提高程序的可读性,注释要精确地描述代码,没有用的注释比没有注释更糟糕. /* */块注释对于被注 ...

  2. 你想了解的《javaScript语言精粹》(三)

    # javaScript语言精粹  # 第三章 对象 - javaScript 数据类型     1. 基础数据类型         Number String Boolean Undefined N ...

  3. JavaScript语言精粹 笔记04 数组

    数组1 数组字面量2 长度3 删除4 列举5 混淆的地方6 方法7 维度 数组1 数组字面量 var empty = []; var numbers = [ 'zero', 'one', 'two', ...

  4. 《JavaScript语言精粹》【PDF】下载

    <JavaScript语言精粹>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230382204 内容简介 javascript曾是&q ...

  5. JavaScript 语言精粹笔记3

    方法 毒瘤 糟粕 记录一下阅读蝴蝶书的笔记,本篇为书中最后一部分:方法.代码风格.优美的特性.毒瘤.糟粕等. 方法 这一章主要介绍了一些方法集.这里写几个我不太熟悉的方法和要点吧. array.joi ...

  6. 《JavaScript语言精粹》小记

    一.前言 以下内容均摘自<JavaScript语言精粹>一书,本人在读这本书时,发现作者诠释JavaScript很犀利,特别是数组部分,固记录下来,想和大家分享下. 随笔主要包含两大部分: ...

  7. javascript语言精粹

    内容选自:<javascript语言精粹> 1.6种值会为假(==false),分别是false,null,undefined,' ',0,NaN 2.typeof有6种值,分别是'num ...

  8. Javascript 语言精粹 代码片段合集

    Javascript 语言精粹 代码片段合集 标签:Douglas-Crockford Javascript 最佳实践 原文链接 更好的阅读体验 使用一个method 方法定义新方法 Function ...

  9. JavaScript语言精粹笔记

    JavaScript语言精粹笔记 掌握语言的每个特性可以让你出风头,但是并不推荐,因为一部分的特性带来的麻烦可能远超本身的价值.正如书中所言,坏的材料并不能雕刻出好的作品,要成为一名更好的程序员,要取 ...

  10. 《JavaScript语言精粹》之函数化

    写在前面 看到好多书评和读书笔记都说<JavaScript语言精粹>字字珠玑,名不虚传..当然,要看得懂才行 其实个人认为函数化部分不是很好,举的例子不是十分恰当,之前看不懂是因为被成功误 ...

随机推荐

  1. php 四种基础算法 ---- 选择排序法

    2. 选择排序法: 选择排序法思路: 每次选择一个相应的元素,然后将其放到指定的位置 代码: function select_sort($arr) {//实现思路 双重循环完成,外层控制轮数,当前的最 ...

  2. Struts2龙之总结

    一.Struts2执行流程: 1.客户端初始化一个指向servlet容器(tomcat)的请求: 2.这个请求经过一系列过滤器(Filter): 3.接着StrutsPrepareAndExecute ...

  3. [转]java构造方法的访问修饰符

    http://my.oschina.net/u/1464678/blog/210359 1.       类(class) 可见性修饰符: public—在所有类中可见,在其他包中可以用import导 ...

  4. BinTools 十六进制转换

    package de.rtner.misc; public class BinTools { public static final String hex = "0123456789ABCD ...

  5. Hadoop学习笔记—5.自定义类型处理手机上网日志

    转载自http://www.cnblogs.com/edisonchou/p/4288737.html Hadoop学习笔记—5.自定义类型处理手机上网日志 一.测试数据:手机上网日志 1.1 关于这 ...

  6. asp 自我定时删除

    <% if now()>"2008-9-15" thenset myfso=server.CreateObject("scripting.filesystem ...

  7. HTNL5新增标签

    我们来看一下HTML 5提供的一些新的标签用法以及和HTML 4的区别. <article>标签定义外部的内容.比如来自一个外部的新闻提供者的一篇新的文章,或者来自 blog 的文本,或者 ...

  8. Ubuntu vim显示行号语法高亮自动缩进

    配置文件名为Ubuntu vimrc在Fedora中vim的配置文件存放在/etc目录中,配置文件名为Ubuntu vimrc在终端 输入以下命令来编辑Ubuntu vimrc配置文件:sudo vi ...

  9. 洛谷U4727 小L 的二叉树

    U4727 小L 的二叉树 题目背景 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣. 所以,小L当时卡在了二叉树. 题目描述 在计算机科学中,二叉树 ...

  10. Android] Android XML解析学习——方式比较

     [Android] Android XML解析学习——方式比较 (ZT)  分类: 嵌入式 (From:http://blog.csdn.net/ichliebephone/article/deta ...