1.基礎(chǔ)類型有哪些待笑?復(fù)雜類型有哪些鸣皂?有什么特征?
簡單數(shù)據(jù)類型
<li>undefined、null寞缝、boolean癌压、number、NaN荆陆、string
特征:簡單數(shù)據(jù)類型保存在棧內(nèi)存中滩届,復(fù)制對值對進行賦值,會開辟一個新的空間被啼。對已經(jīng)被復(fù)制的值進行操作帜消,不會改變原值。
復(fù)雜的數(shù)據(jù)類型
<li>object浓体、Array泡挺、Date、RegExp等
特征:復(fù)雜類型的復(fù)制是對指針的復(fù)制命浴;指針存放于棧中娄猫,實際對象空間在堆中開辟;堆復(fù)制后指針的操作生闲,會影響堆空間中的值媳溺。
2.如下代碼的輸出? 為什么?
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);//false,obj1和obj2是復(fù)雜類型,數(shù)值儲存于堆內(nèi)存中碍讯,此處比較的是兩者的指針悬蔽,兩個指針分別指向不同的堆,所以不相等冲茸。
console.log(obj1 = obj2);//a:1,b:2;把obj2存放的指針地址賦值給obj1屯阀,此時兩者相等了。
console.log(obj1 == obj2);//ture
代碼
寫一個函數(shù)getIntv轴术,獲取從當前時間到指定日期的間隔時間
var str = getIntv("2016-01-08");
console.log(str); // 距除夕還有 20 天 15 小時 20 分 10 秒```
function getinTv(str){
var times = new Date(Date.parse(str)-Date.now());
var year = times.getFullYear()-1970;
var month = times.getMonth();
var date = times.getDate();
var hours = times.getHours();
var minutes = times.getMinutes();
var seconds = times.getSeconds();
return "距除夕還有" +year+ "年" + month + "個月" + date + "天" + hours + "小時" + minutes + "分" + seconds + "秒";
}```
把數(shù)字日期改成中文日期:
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日```
function getChsDate(str){
var arr = str.split('-');
var a = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三','十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九','三十','三十一'];
var year = a[arr[0][0]] + a[arr[0][1]]+ a[arr[0][2]]+ a[arr[0][3]];
var month = a[arr[1][0]]+a[arr[1][1]];
var date = a[arr[2][0]]+a[arr[2][1]];
return year + '年' + month + '月' + date + '日';
}```
寫一個函數(shù)獲取n天前的日期:
var lastWeek = getLastNDays(7); // ‘2016-01-08’
var lastMonth = getLastNDays(30); //'2015-12-15'```
function getLastNDays(date){
var today = Date.now();
var Ndays = date2460601000;
var arr = today - Ndays;
return new Date(arr);
}```
完善如下代碼难衰,用于獲取執(zhí)行時間
var Runtime = (function(){
var ti,t2;
var obj = {
start: function(){
var t1 = new Date();
},
end: function(){
var t2 = new Date();
},
get: function(){
var gettime = t2 - t1;
}
};
return obj;
}());```
##樓梯有200級,每次走1級或是2級逗栽,從底走到頂一共有多少種走法盖袭?用代碼(遞歸)實現(xiàn)
function fn(n){
if(n===1){
return 1;
}else if(n===2){
return 2;
}else{
return fn(n-1)+fn(n-2);
}
}```
寫一個json對象深拷貝的方法,json對象可以多層嵌套彼宠,值可以是字符串鳄虱、數(shù)字、布爾凭峡、json對象中的任意項:
function objCopy(obj){
var newObj = {};
for(var i in obj){
if(typeof obj[i]=== 'object'){
newobj[i] = objCopy(obj[i]);//遞歸,通過不斷的調(diào)用函數(shù)拙已,來深入子對象的層級,一級一級的拷貝摧冀,最后達到深拷貝效果倍踪。
}else{
newObj[i]=obj[i];
}
}
return newObj;
}```