基础类型和复杂类型

  • 基础类型有 数值型、布尔型、字符串、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]