1. 错误对象

        try{
    aa();//这是一个未被定义的方法
    }catch(e){
    alert(e.name+":"+e.message);//输出:ReferenceError:aa is not defined
    }finally{
    alert('我总是被调用');
    }
  2. 对象是通过引用传递的
  3. 数组
    1. 调用时传递一个参数表示数组长度 - var arr=new Array(5)
      超过两个参数则显示指定了数组中的值 - var arr=new Array(1,2,3'name',null,,);
    2. arr.length只能计算索引为非负整数的元素
      1、var arr=[,,] - arr.length的值为2
      2、
      var arr=[1,2,3];
      arr['name']='yolo';//输出3,'name'的索引不是非负整数
      arr[100]='yolo';//输出101,length从0开始计算
      document.write(arr.length); var arr1=[1,2,3,4,5];
      console.log(arr1.length);//输出5
      console.log(arr1);// 输出 "1,2,3,4,5"
      arr1.length=3;
      console.log(arr1);//输出 "1,2,3",相当于删除了第三个之后的元素,如果要删除所有元素,只需要arr1.length=0;
      Object.defineProperty(arr1,'length',{
      writable:false
      });//将length属性设为不可写的
      arr1.length=0;
      console.log(arr1.length);
    3. push()是用来在数组末端添加项,shift()在移除数组的第一个项(前端),实现队列的先进先出FIFO;pop()在数组末端移除项,unshift()在数组前端添加项;(http://blog.csdn.net/rachel_2016/article/details/52448170

  4. 遍历数组
    for循环遍历下标连续的数组
    var arr=[1,2,'name'];
    for(var i=0;i<arr.length;i++){
    console.log(arr[i]);
    } for-in遍历数组,包含继承下来的元素
    var arr=[];
    arr['name']='yolo';
    arr['age']=23;
    for(var i in arr){
    console.log(arr[i]);
    }
    如果只想遍历自身属性,可以加if条件:if(arr.hasOwnProperty(i)) forEach()遍历数组(E大写),同样只能遍历下标连续的数组
    var arr=[1,2,3]
    arr.forEach(function(x){
    console.log(x);
    }) var arr=[1,2,3,4];
    arr['name']='yolo';//forEach循环不能遍历到它
    arr.forEach(my);
    function my(element,index,array){
    console.log('要处理的数组为:'+array);
    console.log('元素索引:'+index+"--元素值:"+element);
    }
    输出:
    要处理的数组为:1,2,3,4
    元素索引:0--元素值:1
    要处理的数组为:1,2,3,4
    元素索引:1--元素值:2
    要处理的数组为:1,2,3,4
    元素索引:2--元素值:3

      

  5.  数组的常用函数
    1.  

       var arr=[1,2,11,20];
          console.log(arr.join('-'));//join指定分隔符,输出: "1-2-11-20"
          console.log(arr.reverse());//reverse反转数组,输出: "20,11,2,1"
          console.log(arr.sort());//sort()按照Unicode排序,输出:"1,11,2,20"
          //可以指定排序函数
          arr.sort(function(a,b){
              return a-b;//如果a比b大,返回一个大于0数,此时b排在a前面,即从小到大排序
          });
          console.log(arr);//输出:"1,2,11,20"
          //通过元素属性排序,输出: "enid"     "join"    "yolo"
          var user=[
              {name:'yolo',age:23},
              {name:'enid',age:18},
              {name:'join',age:22},
              
          ];
          user.sort(function(a,b){
              if(a.name>b.name) return 1;
              if(a.name<b.name) return -1;
              return 0;
          });
          for(var i in user){
              console.log(user[i].name);
          }
          
          
              var arr=[1,2];
          res=arr.concat(3,4);//arr.concat([3,4]);
          res=arr.concat([[3,4,5]]);//输出:[1, 2, Array(3)]
          console.log(res);//输出:"1,2,3,4"     var arr=[1,2,3,4];
          res=arr.slice(0,2);//从数组中截取指定元素,slice(start,length),忽略length,则截取到末尾;输出: "1,2"
          console.log(res);
          
              var arr=['a','b','c','d','e'];
          res=arr.splice(0,1);//从0开始,截取一个元素并返回这个元素,从原数组中删除这个元素
          console.log(res);//输出:"a"
          console.log(arr);//输出:"b,c,d,e"     var arr=['a','b','c','d','e'];
          var res=arr.splice(2);//从2开始截取到最后
          console.log(res);//输出:"c,d,e"
          console.log(arr);//输出:"a,b"     var arr=['a','b','c','d','e'];
          var res=arr.splice(0,2,'!','&','?');//从0开始,截取两个元素,额外添加后面的三个元素
          console.log(res);//输出:"a,b"
          console.log(arr);//输出: "!,&,?,c,d,e"
          
          
              var arr=[1,2,3];
          //map每个元素都调用指定函数
          res=arr.map(function(x){
              return x*x;
          });//输出:"1,4,9"
          console.log(res);
          
              var arr=['a!','b','c!'];
          res=arr.map(my);
          function my(x){
              return x.replace(/!/g,'?').toUpperCase();
          };
          console.log(res);//输出:"A?,B,C?"
          
              var arr=[1,3,5,78];
          res=arr.filter(function(x){
              return x<5;
          });
          console.log(res);//输出:"1,3"
          
                  
          var arr=[1,3,5];
          res=arr.reduce(function(a,b){
              return a+b;
          });
          console.log(res);//输出:9
          //解析:第一次传入:1,3    返回4
      //            第二次传入:4,5     返回9     //every检测是否每个元素都符合条件,some检测是否有一个以上元素符合条件,返回布尔值
          var arr=[1,2,3,18];
          var res=arr.every(function(x){
              return x<=10;
          });
          console.log(res);//输出:false
          
          //indexOf    last
      var arr=['a','b','c','ab','ac','a'];
      var res=arr.indexOf('a');//输出:0
      res=arr.indexOf('A');//不存在,输出-1
      res=arr.indexOf('a',2);//从索引2开始搜索,输出:5
      res=arr.lastIndexOf('a');//输出:5,从最后一个元素开始搜索
      console.log(res); Array.isArray(arr);//检测arr是否是一个数组
      arr.toString();//将数组转换为字符串


04_Javascript初步第二天(下)的更多相关文章

  1. 04_Javascript初步第二天(上)

    全局函数 isFinity() - 检测是否是无穷值(+infinity,-infinity,NaN返回false): isNaN() - 检测是否为数值 encodeURI(uri) - 将字符串编 ...

  2. 【渗透课程】第二篇下-HTTP协议的请求与响应深度剖析

    [渗透课程]第二篇下-HTTP协议的请求与响应深度剖析 HTTP1.1目前支持以下7种请求方法: 常见的MIME类型如下: 第一个数字有五种可能的取值: 目录 什么是请求方法?什么是请求头? HTTP ...

  3. android从放弃到坚持放弃第二课(下)

    续第二课( 下) 续第二课 下 活动的生命周期 返回栈 活动状态 活动的生存期 体验活动的生命周期 活动被回收怎么办 活动的启动模式 standard singleTop singleTask sin ...

  4. Selenium自动化测试第二天(下)

    如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...

  5. 初步了解Windows7下部署Sonar

    1.准备工具: (1)Sonar 8.3版本. (2)PostgresSql 11版本. (3)Java 11. 详细获取地址可参考文章https://www.pianshen.com/article ...

  6. 《JavaScript权威指南》学习笔记 第二天 下好一盘大棋

    前段学习js的时候总是零零散散的,以至于很多东西都模棱两可.时间稍微一久,就容易忘记.最主要的原因是这些东西,原来学的时候就不是太懂,以至于和其他知识无法形成记忆链,所以孤零零的知识特别容易忘记.重温 ...

  7. 04_Javascript初步第三天

    事件 内联模型.脚本模型,DOM2级模型 <!--内联模型--> <input type="button" value="bt1" oncli ...

  8. 04_Javascript初步第一天

    视频来源:麦子学院[看来是麦子的忠实粉丝] 讲师:King我只是想记住对应的中文翻译:Uncaught SyntaxError: missing ) after argument list//属性列表 ...

  9. Shell编程入门(第二版)(下)

    ... ... command n done #select把关键字中的每一项做成类似表单,以交互的方式执行do和done之间的命令 示例-select.sh [python] view plainc ...

随机推荐

  1. 【转载】漫谈HADOOP HDFS BALANCER

    Hadoop的HDFS集群非常容易出现机器与机器之间磁盘利用率不平衡的情况,比如集群中添加新的数据节点.当HDFS出现不平衡状况的时候,将引发很多问题,比如MR程序无法很好地利用本地计算的优势,机器之 ...

  2. js最常用正则表达式集合

    常用正则表达式合集:验证数字:^[0-9]*$验证n位的数字:^\d{n}$验证至少n位数字:^\d{n,}$验证m-n位的数字:^\d{m,n}$验证零和非零开头的数字:^(0|[1-9][0-9] ...

  3. c/s与b/s 动态网站与静态网站 (网站编码统一“UTF-8”)

    1.c/s和b/s 第一张图是b/s  可以随时随地的浏览  (在服务器增加网页就能增加功能,只要改变网页就能使用户同步更新,共享性也强,开发也简单,在广域网和局域网都能建造b/s结构,然后通过int ...

  4. js面向对象学习笔记(四):对象的混合写法

    //对象的混合写法//1.构造函数function 构造函数() { this.属性}构造函数.原型.方法 = function () {};//调用var 对象1 = new 构造函数();对象1. ...

  5. HDU6166-Senior Pan-Dijkstra迪杰斯特拉算法(添加超源点,超汇点)+二进制划分集合-2017多校Team09

    学长好久之前讲的,本来好久好久之前就要写题解的,一直都没写,懒死_(:з」∠)_ Senior Pan Time Limit: 12000/6000 MS (Java/Others)    Memor ...

  6. centos7 hue安装

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  7. [国嵌攻略][097][U-Boot新手入门]

    嵌入式软件层次 1.Bootloader 2.Linux内核 3.文件系统 编译U-Boot 1.解压uboot tar zxvf uboot.tar.gz 2.清除uboot make distcl ...

  8. [国嵌笔记][017][Makefile工程管理]

    Makefile的用途 1.make能够使整个程序的编译.链接只需一个命令就可以完成 2.make的工作主要依赖于Makefile的文件.Makefile文件描述了整个程序的编译.链接等规则,使之自动 ...

  9. Flume介绍

    Flume介绍 http://flume.apache.org/FlumeUserGuide.html 一.Flume架构图 含义 Source 规定收集数据的来源 Channel 相当于一个管道,连 ...

  10. java IO流、集合类部分小知识点总结

    在Java中,以下三个类经常用于处理数据流,下面介绍一下三个类的不同之处以及各自的用法. InputStream : 是所有字节输入流的超类,一般使用它的子类:FileInputStream等,它能输 ...