一、Date
什么是Date?
封装日期和时间,提供操作日期和时间的API。
何时使用日期对象?
今后只要存储日期和时间,都用Date类型的对象
如何创建?4种
1、获取当前系统时间:var now=new Date()
强调:只能获得客户端当前操作系统的时间
2、保存自定义时间:var date=new Date("yyyy/MM/dd hh:mm:ss");
3、复制一个日期对象:
- 为什么要复制?因为今后日期对象的计算,都直接修改原日期对象。计算后,原日期无法保留。
- 何时?只要用户希望同时保留计算前后的开始和结束时间时,都要先复制副本。再用副本计算结束日期时间。
- 如何使用?var date2=new Date(date1);
4、将毫秒数转化为当地时间:因为在系统中存储时间都是使用毫秒数。
- 何时使用:只要将毫秒数转为当地时间显示
- 如何使用?var date=new Date(ms);
- 如何获取毫秒数:var ms=date.getTime();
- 原理:日期对象中,保存的是1970年1月1日0点0分0秒至今的毫秒数
var date=new Date("2017/9/21 10:00");
var ms=date.getTime();
console.log(ms);
API:
-
8个单位
FullYear、Month、Date、Day没有s结尾
Hours、Minutes、Seconds、Milliseconds都有s结尾
-
每个单位都有一对getXXX/setXXX方法
其中:getXXX负责获取指定单位的数值
setXXX负责修改指定单位的数值
-
特例:Day没有set方法
-
取值范围:
Month:0~11
:计算机中每个月份都比现实少1,读取时,+1修正。修改时,-1修正
Date:1~31
day:0~6
Hours:0~23
Minutes/Seconds:0~59
日期计算:2种
1、两日期对象可相减,结果是毫秒差(倒计时计算!)
2、对任意单位的数值做加减:3步
- 取出单位的值
date.getXXX()
- 做加减
- 设置回去
date.setXXX(n)
强调:setXXX()可自动根据n,调整时间进制
如果希望同时保留计算前后的新旧时间,则需要保存复制副本,再用副本计算
简写:date.setXXX(date.getXXX()+n)
****************距离国庆倒计时:**********************
var target=new Date("2017/10/01");
var now=new Date();
var s=parseInt((target-now)/1000);
var d=parseInt(s/(3600*24));
var h=parseInt(s%(3600*24)/3600);
var m=parseInt(s%3600/60);
var s=s%60;
document.write("距离国庆还有:"+d+"天"+h+"小时"+m+"分"+s+"秒");
日期转字符串:
转为当地时间的完整格式:
date.toStrting()
转为当地时间的简化版格式:date.toLocaleString()
转为当地时间的简化版格式,仅保留日期部分:date.toLocaleDateString()
转化为当地时间的简化版格式,仅保留时间部分:date.toLocaleTimeString()
转为国际标准时间:date.toGMTString()
//ex:
//当前时间显示中文版
//2017年09月04日 星期四 下午1:54:29
function format(date){
var week=["日","一","二","三","四","五","六"];
var y=date.getFullYear();
var M=date.getMonth()+1;
if(M<10)
M="0"+M
var d=date.getDay();
if(d<10)
d="0"+d
var day=date.getDay();
day=week[day];
var h=date.getHours();
var am=h<12?"上午":"下午";
if(h>12) h=h-12;
var m=date.getMinutes();
if(m<10) m="0"+m;
var s=date.getSeconds();
if(s<10) s="0"+s;
return y+"年"+M+"月"+d+"日 星期"+day+" "+am+h+":"+m+":"+s;
}
console.log(format(new Date()));
二、Error
-
什么是错误?
程序运行过程中,导致了程序无法正常执行的问题。
程序发生错误后,都会进行中断退出
-
什么是错误处理
当程序发生错误时,依然保证程序不中断退出的机制
何时?只要有可能发生错误的代码,都要提前使用错误处理
try……catch(err) 是一种监视机制,从性能角度考虑,一般用if……else代替掉。
-
如何进行错误处理
try{
可能出现的正常逻辑代码
}catch(err){
一旦出错才执行的错误处理代码:
1、提示用户,2、记录日志,3、保存数据
}
ex:
try{
var num=parseFloat(prompt("输入数字"));
var d=prompt("输入小数位数");
var r=num.toFixed(d);
console.log(r);
console.log("程序继续执行");
}catch(err){
alert("输入有误");
console.log(String(err));
}
-
主动抛出错误:throw new Error("错误信息")
何时使用:函数的作者向函数的调用者抛出的错误提示信息。
在将来开发过程中,需要团队配合。函数创建者无权给页面添加alert等的提示信息,所以使用 throw new Error() 来给函数使用者进行错误提示!
<body>
<form id="form1">
请输入数字:<input name="num" />
请输入小数位数:<input name="d" />
<button id="btn" type="button" value="四舍五入">四舍五入</button>
<div id="sc"></div>
</form>
<script>
//函数创建者
function round(num,d){
if(!isNaN(num)&&!isNaN(d)){//如果两个函数都是数字时执行
num*=Math.pow(10,d);
num=Math.round(num);
return num/Math.pow(10,d);
}else{
throw new Error("必须输入数字");
}
}
//函数使用者
btn.onclick=function(){
try{
sc.innerHTML=round(form1.num.value,form1.d.value);
}catch(err){
sc.innerHTML=String(err);
}
console.log("程序继续执行");
}
</script>
</body>
鄙视题:错误的类型(6种):
- systaxError:语法错误
- ReferenceError:引用错误(俗称找不到对象)
要用的变量/对象没找到! - TypeError:类型错误
错误的使用了类型:
1.错误的使用了()或者[]
2错误的调用了对象的方法 - RangeError:范围错误
参数超范围
数组下标超出范围会不会报错?
答:并不会报错。会在数组栈顶位置添加新值。
- EvalError
- URIError