问答部分
一、基础类型有哪些?复杂类型有哪些?有什么特征?
- 基础类型
- 指的是简单的数据段,包括Undefined、Null、Boolean、Number、String
- 基本类型的特征有:
- 基本类型是按值传递
- 不能给基本类型的值添加属性(尽管这样做不会发生错误),如下代码
var name = "jirengu";
name.age = 2;
console.log(name.age);//undefined,不会报错
- 从一个变量向另一个变量复制基本类型的值,会在变量对象上创建一个新值,**把该值复制到为新变量分配的位置上**,这两个变量可以进行任何操作而不会相互影响,如下代码
var a = 1;
var b = a;
a += 2;
console.log(b);//1
console.log(a);//3
- 复杂类型
- 指那些可能由多个值构成的对象(如:对象、数组、函数、正则)
- 其特征有:
- 按引用访问
- 对于引用类型的值,可以为其添加属性和方法,也可以改变和删除其属性和方法(如果对象不被销毁或这个属性不被删除,则这个属性将一直存在),如下代码
var person = {
name:"hunger"
}
person.age = 25;
console.log(person);
- 从一个变量向另一个变量复制引用类型的值时,会将存储在变量对象中的值复制到为新变量分配的空间中,但是**复制的值是一个指向存储在堆中的一个对象的指针**,如下代码
var person1 = {
name:"hunger"
}
var person2 = person1;
person1.age = 25;
console.log(person2);
二、如下代码的输出? 为什么?
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);
console.log(obj1 = obj2);
console.log(obj1 == obj2);
输出结果如下图所示
原因如下:
var obj1 = {a:1, b:2};//一个obj1的对象
var obj2 = {a:1, b:2};//一个obj2的对象,它和obj1是不同的对象,因为它们指向的内存中的地址不同
console.log(obj1 == obj2);//false,对象是通过指针指向的内存中的地址来做比较是否相等的,两者不
同所以不相等,返回false
console.log(obj1 = obj2);//Object {a: 1, b: 2},将obj2赋值给obj1,则相当于两者有了相同的
指针
console.log(obj1 == obj2);//true,由于两者已经有了相同的指针~即指向内存的地址相同,所有相等
代码部分
一、写一个函数getIntv,获取从当前时间到指定日期的间隔时间
var str = getIntv("2016-01-08");
console.log(str); // 距除夕还有 20 天 15 小时 20 分 10 秒
实现代码如下
function getIntv(date){
var time_cell = Date.parse(date) - Date.now();
var days = Math.floor(time_cell / (24 * 60 * 60 * 1000));
var hours = Math.floor((time_cell - days * 24 * 60 * 60 * 1000) / (60 * 60 * 1000));
var minutes = Math.floor((time_cell - days * 24 * 60 * 60 * 1000 - hours * 60 * 60 * 1000) / (60 * 1000));
var seconds = Math.floor((time_cell - days * 24 * 60 * 60 * 1000 - hours * 60 * 60 * 1000 - minutes * 60 * 1000) / 1000);
var result = "距2017春节还有" + days +"天" + hours + "小时" + minutes + "分钟" + seconds + "秒";
return result;
}
var str = getIntv("2017-01-28");
console.log(str); //距2017春节还有148天14小时28分钟14秒
二、把数字日期改成中文日期
var str = getChsDate('2015-01-08');
console.log(str); // 二零一五年一月八日
实现代码如下
function getChsDate(date){
var ch_num = ["零","一","二","三","四","五","六","七","八","九","十","十一","十二","十三","十四","十五","十六","十七","十八","十九","二十","二十一","二十二","二十三","二十四","二十五","二十六","二十七","二十八","二十九","三十","三十一"];
var date_obj = new Date(date);
var year_arr = date_obj.getFullYear().toString().split("");
var year = [];
for(var i = 0;i < year_arr.length; i++){
year += ch_num[year_arr[i]];
}
var month = ch_num[date_obj.getMonth() + 1];
var day = ch_num[date_obj.getDate()];
var result = year + "年" + month + "月" + day +"日";
return result;
}
三、写一个函数获取n天前的日期
var lastWeek = getLastNDays(7); // ‘2016-01-08’
var lastMonth = getLastNDays(30); //'2015-12-15'
实现代码如下
function getLastDays(num){
var year = new Date(Date.now() - (num * 24 * 60 * 60 *1000)).getFullYear();
var month = new Date(Date.now() - (num * 24 * 60 * 60 *1000)).getMonth() + 1;
var date = new Date(Date.now() - (num * 24 * 60 * 60 *1000)).getDate();
var result = year + "-" + month +"-" + date;
return result;
}
四、完善如下代码,用于获取执行时间如:
var Runtime = (function(){
//code here ...
var obj = {
start: function(){
//code here ..., 当前时间
},
end: function(){
//code here ... 结束时间
},
get: function(){
//code here ... 获取执行时间
}
};
return obj;
}());
Runtime.start();
//todo somethint
Runtime.end();
console.log( Runtime.get() );
实现代码如下
var Runtime = (function(){
var obj = {
start: function(){
start_time = Date.now();
return start_time;
},
end: function(){
end_time = Date.now();
return end_time;
},
get: function(){
time_cell = end_time - start_time;
return time_cell;
}
};
return obj;
}());
Runtime.start();
for(var i = 0;i < 10000;i++){
console.log("jirengu");
}
Runtime.end();
console.log(Runtime.get());
五、楼梯有200级,每次走1级或是2级,从底走到顶一共有多少种走法?用代码(递归)实现
function walkMethod(n){
var result = 0;
if(n === 1){
result = 1;
}else if (n === 2) {
result = 2;
}else{
result = walkMethod(n - 1) + walkMethod(n - 2);
}
return result;
}
当阶梯数较小时可以很快运行出来结果,如下
六、写一个json对象深拷贝的方法,json对象可以多层嵌套,值可以是字符串、数字、布尔、json对象中的任意项
function deepCopy(json){
var new_json = {};
for(var i in json){
if(typeof json[i] === "object"){
new_json[i] = deepCopy(json[i]);
}else{
new_json[i] = json[i];
}
}
return new_json;
}
版权声明:本教程版权归邓攀和饥人谷所有,转载须说明来源!!!!