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

引用类型.时间对象

作者: 谢梦扬_ | 来源:发表于2017-01-14 20:51 被阅读0次

    基础类型有哪些?复杂类型有哪些?有什么特征

    • 基本类型值(数值、布尔值、null undefined string ):指的是保存在栈内存中的简单数据段;
      var a = 1;
      var b = a; //b赋值a,只是简单的数值的拷贝
      a=3;
      console.log(b); //1
    • 引用类型值(对象、数组、函数、正则):指的是那些保存在堆内存中的对象,变量中保存的实际上只是一个指针,这个指针执行内存中的另一个位置,由该位置保存对象。
      var obj1 = {name:'chris',age:'18'};
      var obj2 = obj1; // ,obj1赋给obj2的是指针(指向内存的地址),然后指针指向两个地方, 修改obj1,obj2也会变。
      obj1.name = 'hunger';
      console.log(obj2); // {name:'hunger',age:''18}

    如下代码的输出? 为什么?

     var obj1 = {a:1, b:2};        
     var obj2 = {a:1, b:2};
     console.log(obj1 == obj2);   //fales  因为指向的内存地址不同。
     console.log(obj1 = obj2);   //{a:1,b:2},
     console.log(obj1 == obj2);//true 因为obj2将指针赋给了obj1.
    

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

     var str = getIntv("2016-01-08");
     console.log(str);  // 距除夕还有 20 天 15 小时 20 分 10 秒
    
     function getlntv(str){
             var nowtime = new Date();
            var t = Date.parse(str);
            var spacing =Math.abs( (t-nowtime.getTime())/1000)
            var day = Math.floor(spacing/3600/24);
            var hours = Math.floor(spacing/3600%24);
            var minute = Math.floor(spacing/60%60);
            var seconds = Math.floor(spacing%60);
          if(t-nowtime.getTime()>0){
             return "距离"+str+"还有"+day+"天"+hours+"小时"+minute+"分"+seconds+"秒";
      } else{
             return "离开"+str+"已经"+day+"天"+hours+"小时"+minute+"分"+seconds+"秒";
            }
     }
    

    把数字日期改成中文日期

    var str = getChsDate('2015-01-08');
    console.log(str);  // 二零一五年一月八日
    
     function getChsDate(str){
             var china =['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三','十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九','三十','三十一'];
             var time = new Date(str);
             var year = time.getFullYear()+'';
             var month = time.getMonth()+1+'';
             var date = time.getDate()+'';
             var t = '';
        for(i =0;i<year.length;i++){
              t +=china[year[i]];
    }
              return t+'年'+china[month]+'月'+china[date]+'日';
    }
    

    写一个函数获取n天前的日期

     var lastWeek =  getLastNDays(7); // ‘2016-01-08’
     var lastMonth = getLastNDays(30); //'2015-12-15'
    
    function getLastNDays(days){
            var lasttime = Date.now()-days*24*3600*1000;
            var lastdate = new Date(lasttime);
            var year = lastdate.getFullYear()+'';
            var month = lastdate.getMonth()+1+'';
            var date = lastdate.getDate()+'';
            return year+'-'+month+'-'+date;
    

    }

    完善如下代码,用于获取执行时间如:

          var Runtime = (function(){
     var startTime, endTime, getTime ;
    var obj = {
        start: function(){
             var startTime = Date.now();// 当前时间
        },
        end: function(){
            var endTime = Date.now();// 结束时间
        },
        get: function(){
            return var getTime = endTime-startTime;// 获取执行时间
        }
    };
    return obj;
    }());
    Runtime.start();
     for(i = 0;i<10000;i++){
          console.log(1)
    }
    Runtime.end();
    console.log(  Runtime.get() );
    

    楼梯有20级,每次走1级或是2级,从底走到顶一共有多少种走法?用代码(递归)实现

                   function fn(sum){
                        if(sum === 1){
                            return 1;
          }else  if(sum === 2){
                   return 2;
          }else if(sum > 2){
                   return fn(sum-1)+fn(sum-2);
          }
      }
    

    写一个json对象深拷贝的方法,json对象可以多层嵌套,值可以是字符串、数字、布尔、json对象中的任意项(PS:尝试另外一种方法 var obj2 = JSON.parse( JSON.stringify(obj1) )

          function copy(obj){
             var newobj = {};
            for(var i in obj){
            if( typeof(obj[i]) === 'object'){
                newobj[i] = copy(obj[i])
            }else{
                newobj[i] = obj[i]
            }
        }
              return newobj;
     }
    第二种方法:
         function copy(obj){
                var newobj = JSON.parse(JSON.stringify(obj));
                 return newobj;
      }
    

    相关文章

      网友评论

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

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