日期:2014-05-16  浏览次数:20354 次

请问一个求2个now()时间差的问题,谢谢
我用rs查询出多条数据库记录, 其中每一条都包含有开始日期,结束日期.
我想在asp中每一条记录后面都加个文本框显示出对应的这2个日期的时间差, 格式为 小时:分钟:秒. 请问用什么办法吗?

我自己找了点方法,但是没成功,请高人也帮我看看吧..错误在哪里.

最好可以页面一打开就自动计算出来的.

<input name="sj" type="text" id="sj" onclick="TimeDiff(<%=rs("wcrq")%>,<%=rs("gjrq")%>)" size="10" >

这个是函数
JScript code

<script type="text/javascript">
Function TimeDiff(sBegin,sEnd) 
Dim iHourB, iMinuteB, iSecondB, iMiniSecondB 
Dim iHourE, iMinuteE, iSecondE, iMiniSecondE 
Dim dTimeB, dTimeE, dTimeDiff 
Dim iHour, iMinute, iSecond, iMiniSecond 

iHourB = clng(Left(sBegin, 2)) 
iMinuteB = clng(Mid(sBegin, 4, 2)) 
iSecondB = clng(Mid(sBegin, 7, 2)) 
iMiniSecondB = clng(Mid(sBegin, 10, 4)) 

iHourE = clng(Left(sEnd, 2)) 
iMinuteE = clng(Mid(sEnd, 4, 2)) 
iSecondE = clng(Mid(sEnd, 7, 2)) 
iMiniSecondE = clng(Mid(sEnd, 10, 4)) 

dTimeB = iHourB * 3600 + iMinuteB * 60 + iSecondB + iMiniSecondB / 1000 
dTimeE = iHourE * 3600 + iMinuteE * 60 + iSecondE + iMiniSecondE / 1000 
dTimeDiff = dTimeE - dTimeB 

iHour = Int(dTimeDiff / 3600) 
dTimeDiff = dTimeDiff - iHour * 3600 
iMinute = Int(dTimeDiff / 60) 
dTimeDiff = dTimeDiff - iMinute * 60 
iSecond = Int(dTimeDiff) 
dTimeDiff = dTimeDiff - Int(dTimeDiff) 
iMiniSecond = dTimeDiff 

TimeDiff = iHour & "小时" & iMinute & "分钟" & iSecond & FormatNumber(iMiniSecond, 3) & "秒"

document.getElementById("sj").value=TimeDiff;
End Function 
</script>



------解决方案--------------------
asp不很懂 但你可以查查有没有这样的方法 就是把开始和结束日期转换成格林威治时间 就是从1970年几月几号到现在的毫秒数,然后用结束日期的格林威治时间减去开始时间的格林威治时间,算出两者的毫秒数的差,然后转换成时分秒试试