【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实现json

    <?PHP function __json_encode( $data ) { if( is_array($data) || is_object($data) ) { $islist = is_ ...

  2. jQuery 数据滚动(上下)

    setInterval(function() { jq('.sjbg02 li:first').animate({ 'height': '0', 'opacity': '0' }, 'slow', f ...

  3. js 基础对象一

    JavaScript 通常用于操作 HTML 元素. Document元素 每个载入浏览器的 HTML 文档都会成为 Document 对象. Document 对象使我们可以从脚本中对 HTML 页 ...

  4. 转:LoadRunner获取毫秒及字符串替换实现

    今天做一个性能测试,参数化要求创建用户名不可以重复,想来想不没有什么好的办法来避免用户名字的重复.所以就想用时间+随机数来实现,但是实现中遇到一个问题. 名字中不可以包含.这个特殊的字符的.所以要处理 ...

  5. 编写一条sql命令,sql删除没有中文的表

    删除包含中文的 和不饱和中文的字段 SHOW create table pages; drop table if exists `film`; CREATE TABLE `film` ( `id` i ...

  6. angularjs ng-switch

    <p> <a href="#" ng-click="toggle()">Toggle Section</a> </p& ...

  7. Android系统权限及签名

    Android系统权限及签名   2015-03-23 19:13:33CSDN-chen52671-点击数:50     Android权限及签名 引子 现象:系统中的一个定制Service,服务是 ...

  8. STM32片上Flash内存映射、页面大小、寄存器映射

    STM32片上Flash内存映射.页面大小.寄存器映射 STM32有4种Flash module organization,分别是:low-density devices(32KB,1KB/page) ...

  9. 关于svn的安装问题

    直接把安装包放在 MyEclipse的安装目录下 如果 报错 那么就重装MyEclipse 半个小时左右就OK了不然调错太浪费时间了

  10. FusionCharts使用问题及解决方法(三)-FusionCharts常见问题大全

    前两篇文章中,我们总结了FusionCharts图表的一些常见问题(FAQ)及解决方法,本文继续讨论FusionCharts使用者常见的一些复杂的报错及解决方法. 当HTML.SWF和JavaScri ...