時間物件、引用型別

Zegendary發表於2017-12-13

###問題

  • 基礎型別有哪些?複雜型別有哪些?有什麼特徵? 基礎型別:String 型別、Null 型別、Number 型別、Undefined型別、Boolean 型別 複雜型別:Object 型別 作用: String型別: String是Unicode字元組成的序列,俗稱字串,可以用雙引號或者單引號表示,沒有區別,匹配即可 Null型別: Null型別只有一個值:null,表示空指標,也就是不存在的東西 Number型別: JavaScript的數字型別和其它語言有所不同,沒有整型和浮點數的區別,統一都是Number型別,可以表示十進位制、八進位制、十六進位制 Undefined型別: Undefined型別也只有一個值undefined,表示變數只被宣告,沒有被初始化,也就是有這個指標,但是這個指標沒有指向任何空間 Boolean型別: Boolean有兩個值:1.true2.false Object型別: 物件(object)是JavaScript的核心概念,也是最重要的資料型別。JavaScript的所有資料都可以被視為物件,這也是我們常說的一切皆為物件。
  • 如下程式碼的輸出? 為什麼? var obj1 = {a:1, b:2}; var obj2 = {a:1, b:2}; console.log(obj1 == obj2);//false,由於obj1與obj2所儲存的位置不同,所以false。 console.log(obj1 = obj2);//obj2賦值給obj1 輸出 Object { a=1, b=2} 內容。 console.log(obj1 == obj2);//把obj2賦值給obj1,所以obj2與obj1儲存的位置是一樣的,所以為true。

程式碼

  • 寫一個函式getIntv,獲取從當前時間到指定日期的間隔時間。
    var str = getIntv("2016-01-08"); console.log(str); // 距除夕還有 20 天 15 小時 20 分 10 秒 程式碼: var str = getIntv("2017-01-27"); function getIntv(time){ var end = new Date(time); var now = new Date(); var timer = end-now; var day = Math.floor(timer/(1000606024)); var timer1 = timer%(1000606024) var hour = Math.floor(timer1/(10006060)); var timer2 = timer1%(10006060); var min = Math.floor(timer2/(100060)); var timer3 = timer2%(100060); var sec = Math.floor(timer3/1000); return ("距"+time+"還有"+day+"天"+hour+"小時"+min+"分鐘"+sec+"秒") } console.log(str); // 距2017-01-27還有 20 天 15 小時 20 分 10 秒

  • 把數字日期改成中文日期,如: var str = getChsDate('2015-01-08'); console.log(str); // 二零一五年一月八日 程式碼: 方法一: var str = getChsDate('2015-01-08'); function getChsDate(time){ time = time.replace(/-/g,''); var arr = [] for(i=0;i<time.length;i++){ switch(time[i]){ case '0': arr.push('零');break; case '1': arr.push('一');break; case '2': arr.push('二');break; case '3': arr.push('三');break; case '4': arr.push('四');break; case '5': arr.push('五');break; case '6': arr.push('六');break; case '7': arr.push('七');break; case '8': arr.push('八');break; case '9': arr.push('九');break; } } console.log(time); arr.splice(4,0,'年'); arr.splice(7,0,'月'); arr.splice(10,0,'日'); arr = arr.join('');
    return arr; }//這種方法有一定缺陷,比如'2016-02-28',輸出'二零一六年零二月二八日',讀起來很彆扭 console.log(str); // 二零一五年一月八日 方法二: function getChsDate(date){ var newDate =date.split("-"), year = newDate[0], month = newDate[1], day = newDate[2]; var dict ={"0":"零","1": "一", "2": "二", "3": "三","4": "四","5": "五","6": "六","7": "七", "8": "八", "9": "九", "10": "十", "11": "十一", "12": "十二","13": "十三", "14": "十四", "15": "十五", "16": "十六", "17": "十七", "18": "十八", "19": "十九","20": "二十","21": "二十一", "22": "二十二", "23": "二十三", "24": "二十四", "25": "二十五","26": "二十六", "27": "二十七", "28": "二十八", "29": "二十九", "30": "三十", "31": "三十一"}; return dict[year[0]]+dict[year[1]]+dict[year[2]]+dict[year[3]] + '年' + dict[Number(month)] +'月' + dict[Number(day)] + '日'; }; getChsDate('2015-01-08');//"二零一五年一月八日"

  • 寫一個函式獲取n天前的日期:

      var lastWeek =  getLastNDays(7); // ‘2016-01-08’
      var lastMonth = getLastNDays(30); //'2015-12-15'
    複製程式碼

    程式碼: var lastWeek = getLastNDays(7); // ‘2016-01-08’ var lastMonth = getLastNDays(30); //'2015-12-15' function getLastNDays(dater){ var now = Date.now(); var timer = dater2460601000; var past = new Date(now - timer); var year = past.getFullYear(); var month = past.getMonth()+1;//月份從0開始算; var day = past.getDate(); return year+'-'+month+'-'+day; } console.log(lastWeek); console.log(lastMonth);

  • 完善如下程式碼,如: var Runtime = (function(){ //code here ... return { start: function(){ //code here ... }, end: function(){ //code here ... }, get: function(){ //code here ... } }; }()); Runtime.start(); //todo somethint Runtime.end(); console.log( Runtime.get() ); 程式碼: var Runtime = (function(){ var time1; var time2; return { start: function(){ time1=Date.now(); }, end: function(){ time2=Date.now(); }, get: function(){ return (time2-time1); } }; }()); Runtime.start(); for(var i=0;i<100;i++){ console.log(1);//輸出100次1 } Runtime.end(); console.log( Runtime.get() );//執行了22ms

  • 樓梯有200級,每次走1級或是2級,從底走到頂一共有多少種走法?用程式碼(遞迴)實現 function fn(num) { if (num==0||num==1) { return 1; } else { return fn(num-1)+fn(num-2); } } console.log(fn(200));

  • 寫一個json物件深拷貝的方法,json物件可以多層巢狀,值可以是字串、數字、布林、json物件中的任意項 var json={ "name":"yahoo", "age":"14", "sex":"man", "address": { "streetAddress": "21 2nd Street", "city": "New York", "state": "NY", "postalCode": "10021" } } function JSON(arr){ var newjson= {}; for(key in arr){ if(typeof arr[key]=="object"){ newjson[key]=JSON(arr[key]); } else{ newjson[key]=arr[key]; } } return newjson; } console.log(JSON(json))

  • 寫一個陣列深拷貝的方法,陣列裡的值可以是字串、數字、布林、陣列中的任意專案 var arr=[1,"2",3,[1,2,3,4],true] function JSON(arr){ var newarr=[]; for(key in arr){ if(typeof arr[key] =='Array') { newarr[key]=JSON(arr[key]); } else{ newarr[key]=arr[key]; } } return newarr; } console.log(JSON(arr))

  • 寫一個深拷貝的方法,拷貝物件以及內部巢狀的值可以是字串、數字、布林、陣列、json物件中的任意項 var O={ name:"yahoo", age:14, other:[1,2,true,"yahoo",3], man:{ "man1":"woman", "man2":"man2" }, aid:true, address: { streetAddress: "21 2nd Street", city: "New York", state: "NY", postalCode: "10021" } } function JOSN(O){ var newarr={}; for(key in O){ if (typeof O[key] ==='Array'){ newarr[key]=JOSN(O[key]); } else{ newarr[key]=O[key]; }
    } return newarr; } console.log(JOSN(O))

相關文章