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