任务19-时间对象、引用类型

问答

1. 基础类型有哪些?复杂类型有哪些?有什么特征?

  • 基础类型:Number、Boolean、Null、Undefined、String。
    特征:基础类型指的是保存在栈内存中的简单数据段,它是按值访问,操作的是它们实际保存的值;基础类型从一个变量向一个变量复制时,会在栈中创建一个新值,然后把值复制到为新变量分配的位置上。
  • 复杂类型:对象、数组、函数、正则。
    特征:复杂类型指的是是那些保存在堆内存中的对象,变量中保存的实际上只是一个指针,这个指针执行内存中的另一个位置,由该位置保存对象。

2. 如下代码的输出? 为什么?

<pre>
var obj1 = {a:1, b:2}; var obj2 = {a:1, b:2}; console.log(obj1 == obj2); console.log(obj1 = obj2); console.log(obj1 == obj2);
</pre>

输出结果及原因:
<pre>
var obj1 = {a:1, b:2}; var obj2 = {a:1, b:2}; console.log(obj1 == obj2);// false obj1和obj2代表了两个不同的对象,尽管它们的内容相同,但其内部的地址,以及地址所指引的空间都不相同,所以它们是两个对象。 console.log(obj1 = obj2);//Object {a: 1, b: 2} 对象obj2赋值给obj1,obj1的内存改变了,指向同一个位置了。 console.log(obj1 == obj2);//true 经过上述步骤之后,两个变量均指向同一位置,所以返回true。
</pre>

代码

1. 写一个函数getIntv,获取从当前时间到指定日期的间隔时间

<pre>
var str = getIntv("2016-01-08");
console.log(str); // 距除夕还有 20 天 15 小时 20 分 10 秒
</pre>

代码如下:
<pre>
function getIntv(val){
var now = new Date();
var schedule = new Date(val);
var result = schedule - now;
var days = Math.floor(result/(24*60*60*1000));
var hours = Math.floor((result-days*24*60*60*1000)/(60*60*1000));
var minutes = Math.floor((result-days*24*60*60*1000-hours*60*60*1000)/(60*1000));
var seconds = Math.floor((result-days*24*60*60*1000-hours*60*60*1000-minutes*60*1000)/1000);
var str="距离双十一还有"+days+"天"+hours+"小时"+minutes+"分钟"+seconds+"秒";
return str;
}
var str = getIntv ("2016-11-11");
console.log(str);
</pre>

输出结果:

2. 把数字日期改成中文日期

<pre>
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日
</pre>

代码如下:
<pre>function getChsDate(str){ var timeChin = ["零","一", "二", "三", "四", "五", "六", "七", "八", "九", "十", "十一", "十二", "十三", "十四", "十五", "十六", "十七", "十八", "十九", "二十", "二十一", "二十二", "二十三", "二十四", "二十五", "二十六", "二十七", "二十八", "二十九", "三十", "三十一"]; if(!(new Date(str).getDate()==str.substring(str.length-2))) { alert("Oh,输入的日期不对!"); return; } var date = new Date(Date.parse(str)); var arr = String(date.getFullYear()).split(""); var year = ""; for(var i = 0;i < arr.length;i++){ year += timeChin[Number(arr[i])]; } var month = timeChin[date.getMonth() + 1]; var date = timeChin[date.getDate()]; return year + "年" + month + "月" + date + "日"; }
</pre>

输出结果:

3. 写一个函数获取n天前的日期

<pre>var lastWeek = getLastNDays(7); // ‘2016-01-08’ var lastMonth = getLastNDays(30); //'2015-12-15'</pre>

代码如下:
<pre>
function getLastNDays(n){
var milliseconds = new Date() - n*24*60*60*1000
var date = new Date(milliseconds);
var year = date.getFullYear();
var month = date.getMonth() + 1;
var date = date.getDate();
return year +"年"+month+"月"+date+"日";
}
</pre>

输出结果:

4. 楼梯有200级,每次走1级或是2级,从底走到顶一共有多少种走法?用代码(递归)实现

这就是一个斐波那契数列:
登上第一级台阶有一种登法;
登上两级台阶,有两种登法;
登上三级台阶,有三种登法;
登上四级台阶,有五种登法;
......
登上n级台阶,有f(n-1)+f(n-2)种登法。
<pre>
`function febSteps(number) {
if (number < 1) {
return;
}
if (number === 1) {
return 1;
} else if (number === 2) {
return 2;
} else {
return febSteps(number - 1) + febSteps(number - 2);
}
}

console.log(febSteps(10));
console.log(febSteps(20));
console.log(febSteps(30));
console.log(febSteps(40));
...
console.log(febSteps(200));`
</pre>

5. 完善如下代码,用于获取执行时间如:

  • 将4,5这两道题的顺序调换一下,个人觉得有这两道题可以联系起来处理,在这道题中,我们可以用上道题作为例子,可以更直观的展现如何获取执行时间,因为根据输出结果,我们会发现递归越深,执行的时间就会越久。
    <pre>
    function febSteps(number) { if (number < 1) { return; } if (number === 1) { return 1; } else if (number === 2) { return 2; } else { return febSteps(number - 1) + febSteps(number - 2); } } var Runtime = (function(){ var startTime,endTime; var obj = { start: function(){ //code here ..., 当前时间 startTime = Date.now(); }, end: function(){ //code here ... 结束时间 endTime = Date.now(); }, get: function(){ //code here ... 获取执行时间 return endTime-startTime; } }; return obj; }()); for(var i=30;i<45;i++){ Runtime.start(); //todo something febSteps(i); Runtime.end(); console.log( "走"+ i + "级台阶,运行时间是:" + Runtime.get() + "ms"); }</pre>

输出结果:

6. 写一个json对象深拷贝的方法,json对象可以多层嵌套,值可以是字符串、数字、布尔、json对象中的任意项

<pre>`
var Fairy = {
  "birthDay":"1984.01.01",

}
var Snow= {
  "birthYear":"1980",
}

function deepCopy(copyFrom, copyTo) {
    var copyTo = copyTo || {};
    for (var i in copyFrom) {
      if (typeof copyFrom[i] === 'object') {
        copyTo[i] = (copyFrom[i].constructor === Array) ? [] : {};
        deepCopy(copyFrom[i], copyTo[i]);
      } else {
         copyTo[i] = copyFrom[i];
      }
    }
    return copyTo;
  }

var Snow = deepCopy(Fairy,Snow );
Snow.birthYear = "1985";
console.log (Snow.birthYear);
console.log (Fairy.birthDay);

Fairy.address = ["湖北","武汉"];
var Snow =deepCopy(Fairy,Snow );
Snow.address.push("光谷");

console.log(Snow.address);
console.log(Fairy.address);
`</pre>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,961评论 5 473
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,444评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,009评论 0 333
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,082评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,101评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,271评论 1 278
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,738评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,395评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,539评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,434评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,481评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,160评论 3 317
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,749评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,816评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,038评论 1 256
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,548评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,140评论 2 341

推荐阅读更多精彩内容