JS的时间对象与引用类型是什么
这篇文章主要讲解了"JS的时间对象与引用类型是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"JS的时间对象与引用类型是什么"吧!
基础类型: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的所有数据都可以被视为对象,这也是我们常说的一切皆为对象。
如下代码的输出?为什么?
varobj1={a:1,b:2};
varobj2={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,获取从当前时间到指定日期的间隔时间。
varstr=getIntv("2016-01-08");
console.log(str);//距除夕还有20天15小时20分10秒
代码:
varstr=getIntv("2017-01-27");
functiongetIntv(time){
varend=newDate(time);
varnow=newDate();
vartimer=end-now;
varday=Math.floor(timer/(1000606024));
vartimer1=timer%(1000606024)
varhour=Math.floor(timer1/(10006060));
vartimer2=timer1%(10006060);
varmin=Math.floor(timer2/(100060));
vartimer3=timer2%(100060);
varsec=Math.floor(timer3/1000);
return("距"+time+"还有"+day+"天"+hour+"小时"+min+"分钟"+sec+"秒")
}
console.log(str);//距2017-01-27还有20天15小时20分10秒
把数字日期改成中文日期,如:
varstr=getChsDate('2015-01-08');
console.log(str);//二零一五年一月八日
代码:
方法一:
varstr=getChsDate('2015-01-08');
functiongetChsDate(time){
time=time.replace(/-/g,'');
vararr=[]
for(i=0;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(''); returnarr; }//这种方法有一定缺陷,比如'2016-02-28',输出'二零一六年零二月二八日',读起来很别扭 console.log(str);//二零一五年一月八日 方法二: functiongetChsDate(date){ varnewDate=date.split("-"), year=newDate[0], month=newDate[1], day=newDate[2]; vardict={"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":"三十一"}; returndict[year[0]]+dict[year[1]]+dict[year[2]]+dict[year[3]]+'年'+dict[Number(month)]+'月'+dict[Number(day)]+'日'; }; getChsDate('2015-01-08');//"二零一五年一月八日" 写一个函数获取n天前的日期: varlastWeek=getLastNDays(7);//‘2016-01-08’ varlastMonth=getLastNDays(30);//'2015-12-15' 代码: varlastWeek=getLastNDays(7);//‘2016-01-08’ varlastMonth=getLastNDays(30);//'2015-12-15' functiongetLastNDays(dater){ varnow=Date.now(); vartimer=dater2460601000; varpast=newDate(now-timer); varyear=past.getFullYear(); varmonth=past.getMonth()+1;//月份从0开始算; varday=past.getDate(); returnyear+'-'+month+'-'+day; } console.log(lastWeek); console.log(lastMonth); 完善如下代码,如: varRuntime=(function(){ //codehere... return{ start:function(){ //codehere... }, end:function(){ //codehere... }, get:function(){ //codehere... } }; }()); Runtime.start(); //todosomethint Runtime.end(); console.log(Runtime.get()); 代码: varRuntime=(function(){ vartime1; vartime2; return{ start:function(){ time1=Date.now(); }, end:function(){ time2=Date.now(); }, get:function(){ return(time2-time1); } }; }()); Runtime.start(); for(vari=0;i<100;i++){ console.log(1);//输出100次1 } Runtime.end(); console.log(Runtime.get());//运行了22ms 楼梯有200级,每次走1级或是2级,从底走到顶一共有多少种走法?用代码(递归)实现 functionfn(num){ if(num==0||num==1){ return1; } else{ returnfn(num-1)+fn(num-2); } } console.log(fn(200)); 写一个json对象深拷贝的方法,json对象可以多层嵌套,值可以是字符串、数字、布尔、json对象中的任意项 varjson={ "name":"yahoo", "age":"14", "sex":"man", "address": { "streetAddress":"212ndStreet", "city":"NewYork", "state":"NY", "postalCode":"10021" } } functionJSON(arr){ varnewjson={}; for(keyinarr){ if(typeofarr[key]=="object"){ newjson[key]=JSON(arr[key]); } else{ newjson[key]=arr[key]; } } returnnewjson; } console.log(JSON(json)) 写一个数组深拷贝的方法,数组里的值可以是字符串、数字、布尔、数组中的任意项目 vararr=[1,"2",3,[1,2,3,4],true] functionJSON(arr){ varnewarr=[]; for(keyinarr){ if(typeofarr[key]=='Array'){ newarr[key]=JSON(arr[key]); } else{ newarr[key]=arr[key]; } } returnnewarr; } console.log(JSON(arr)) 写一个深拷贝的方法,拷贝对象以及内部嵌套的值可以是字符串、数字、布尔、数组、json对象中的任意项 varO={ name:"yahoo", age:14, other:[1,2,true,"yahoo",3], man:{ "man1":"woman", "man2":"man2" }, aid:true, address: { streetAddress:"212ndStreet", city:"NewYork", state:"NY", postalCode:"10021" } } functionJOSN(O){ varnewarr={}; for(keyinO){ if(typeofO[key]==='Array'){ newarr[key]=JOSN(O[key]); } else{ newarr[key]=O[key]; } } returnnewarr; } console.log(JOSN(O)) 感谢各位的阅读,以上就是"JS的时间对象与引用类型是什么"的内容了,经过本文的学习后,相信大家对JS的时间对象与引用类型是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!