基礎類型和復雜類型
- 基礎類型有 數值型、布爾型、字符串、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]