<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style type="text/css"> span{ font-size: 5em; color: red; } </style> </head> <body> <h2>计算日期间隔</h2> <p><label>请选择起始日期:</label><input id="d1" type="date"/></p> <p><label>请选择结束日期:</label><input id="d2" type="date"/></p> <p><input type="button" value="计算" id="btn"/><span id="show"></span></p> <script type="text/javascript"> var d1=document.getElementById("d1"); var d2=document.getElementById("d2"); var btn=document.getElementById("btn"); var show=document.getElementById("show"); btn.onclick=function(){ var begin,end,diff; if(d1.value==""||d2.value==""){ show.innerText="起始日期或结束日期未选择!"; }else{ begin=getTimeStamp(d1.value); end=getTimeStamp(d2.vale); diff=Math.abs(begin-end)/1000/60/60/24 ; show.innerText=d1.value +"和" +d2.value+"相差"+diff+"天"; } } function getTimeStamp(dateString){ var date=new Date(dateString); return date.getTime(); } </script> </body> </html>改正
时间: 2023-08-14 18:22:52 浏览: 97
这段代码存在以下几处错误:
1. 在JS代码中,获取结束日期时写成了"d2.vale",应该改为"d2.value"。
2. 在JS代码中,计算相差天数时应该使用Math.round方法对计算结果进行四舍五入。
3. 在JS代码中,代码执行时应该先判断d1和d2的value属性是否为空,而不是在getTimeStamp函数中判断。
4. 在JS代码中,计算时间戳时,应该使用new Date(dateString).getTime()方法,而不是Date.parse(dateString)。
修改后的代码如下:
```
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style type="text/css">
span{
font-size: 5em;
color: red;
}
</style>
</head>
<body>
<h2>计算日期间隔</h2>
<p><label>请选择起始日期:</label><input id="d1" type="date"/></p>
<p><label>请选择结束日期:</label><input id="d2" type="date"/></p>
<p><input type="button" value="计算" id="btn"/><span id="show"></span></p>
<script type="text/javascript">
var d1=document.getElementById("d1");
var d2=document.getElementById("d2");
var btn=document.getElementById("btn");
var show=document.getElementById("show");
btn.onclick=function(){
var begin,end,diff;
if(d1.value==""||d2.value==""){
show.innerText="起始日期或结束日期未选择!";
}else{
begin=getTimeStamp(d1.value);
end=getTimeStamp(d2.value);
diff=Math.round(Math.abs(begin-end)/1000/60/60/24);
show.innerText=d1.value +"和" +d2.value+"相差"+diff+"天";
}
}
function getTimeStamp(dateString){
var date=new Date(dateString);
return date.getTime();
}
</script>
</body>
</html>
```
阅读全文