美文网首页
JavaScript 时间对象、引用类型

JavaScript 时间对象、引用类型

作者: 柯良勇 | 来源:发表于2016-05-25 15:22 被阅读9次

    基础类型和复杂类型

    • 基础类型有 数值型、布尔型、字符串、null和undefined;特征是都比较简单,占用空间小使用的是栈内存类似一片规划好的整齐排列的地;变量名所在的空间里存放的就是具体值。
    • 复杂类型有 数组、函数、对象、正则;特征是较复杂是简单类型组合而成的数据,占用空间较大,家门口的田地放不下,使用的是堆内存类似去草原圈一块地,一般变量名里存放的是指向堆内存的地址,就好像在家门口那块地放上一张去草原那块地的地图一样。

    基础类型和复杂类型实践

      var obj1 = {a:1, b:2};
      var obj2 = {a:1, b:2};
      console.log(obj1 == obj2); // false  obj1/2里存放的是两个不同的地址 两个地址指向两个地方 虽然这两个地方放的东西是一样的 但本质上这两个地址是不同的  
      console.log(obj1 = obj2); // 输出obj1   将obj2里存的地址赋给obj1后 会返回变更后的obj1
      console.log(obj1 == obj2); // true obj1和obj2存的是同一个地址 两者相等
    

    小练习

    函数getIntv,获取从当前时间到指定日期的间隔时间

    function getIntv(char){
      var intv=(Date.parse(char)-Date.now());
      var a=1000*60*60*24;
      var day=Math.floor(intv/a);
      var hours=Math.floor((intv-day*a)/a*24);
      var minute=Math.floor((intv-day*a-hours*a/24)/a*24*60);
      var second=Math.floor((intv-day*a-hours*a/24-minute*a/24/60)/a*24*60*60);
      return '倒计时'+day+'天'+hours+'小时'+minute+'分'+second+'秒';
    }
    var str = getIntv("2016-05-01");
    console.log(str);  // 倒计时7天18小时22分4秒
    

    函数getChsDate(char)把数字日期改成中文日期

    function getChsDate(char){
      var char=(char.split('-'));
      var newarr=[];
      chs=['零','一','二','三','四','五','六','七','八','九','十'];
      for(var i in char){
        newarr.push(char[i].split(''));
      }
      year=chs[newarr[0][0]]+chs[newarr[0][1]]+chs[newarr[0][2]]+chs[newarr[0][3]]+'年';
      if ([newarr[1][0]===1]){
        month='十'+chs[newarr[1][1]]+'月';
      }else {
        month=chs[newarr[1][1]]+'月';
      }
      switch (newarr[2][0]){
        case "0":
        day=chs[newarr[2][1]]+'日';break;
        case "1":
        day='十'+chs[newarr[2][1]]+'日';break;
        case "2":
        day='二十'+chs[newarr[2][1]]+'日';break;
        default:
        day='三十'+chs[newarr[2][1]]+'日';
      }
      month=month.replace('零','');
      day=day.replace('零','');
      return year+month+day;
    }
    var str = getChsDate('2015-10-10');
    console.log(str);  // 二零一五年十月十日
    

    函数getLastNDays(num)获取n天前的日期

    function getLastNDays(num){
      var time=new Date(Date.now()-num*24*3600*1000);
      return time.getFullYear()+'-'+time.getMonth()+'-'+time.getDate();
    }
    var lastWeek =  getLastNDays(7); // "2016-3-16"
    var lastMonth = getLastNDays(30); // "2016-2-24"
    

    计算一段代码运行的时间

    var Runtime = (function(){
      return {
        start: function(){
          t1=Date.now();
        },
        end: function(){
          t2=Date.now();
        },
        get: function(){
          return '这段代码运行的时间为:'+((t2-t1)/1000)+'秒';
        }
      };
    }());
    Runtime.start();
    for (var i=0;i<10000;i++)
      console.log(1);
    Runtime.end();
    console.log(  Runtime.get() ); // 这段代码运行的时间为:1.069秒
    

    楼梯有200级,每次走1级或是2级,从底走到顶一共有多少种走法?

    function way(step){
      if (step<2){
        step=1;
      }else {
        step=way(step-1)+way(step-2);
      }
      return step; 
    }
    console.log(way(7));    //  21种方法  7级台阶
    console.log(way(10));   //  89        10级台阶
    console.log(way(15));   //  987       15级台阶
    console.log(way(45)); // 1836311903 45级台阶
    

    一个深拷贝的方法,运用递归

    function arrayCopy(obj){
      var newobj=obj;
      for(i in obj){
        if(typeof obj[i]!=='object')
          newobj[i]=obj[i];
        else{
          newobj[i]=arrayCopy(obj[i]);
        }
      }
      return newobj;
    }
    var obj1={"array":[4,5,[2,3,5,],78],"name": "张三", "工作同事":{"name": "李四", "habit": "爬山"}};
    var obj2=arrayCopy(obj1);  // Object {array: Array[4], name: "张三", 工作同事: Object}
    var obj3=[4,5,[2,3,5,],78,{"name": "张三", "工作同事":{"name": "李四", "habit": "爬山"}}];
    var obj4=arrayCopy(obj3);  // [4, 5, Array[3], 78, Object]

    相关文章

      网友评论

          本文标题:JavaScript 时间对象、引用类型

          本文链接:https://www.haomeiwen.com/subject/mjjtdttx.html