手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaScript获取服务器端时间的方法
JavaScript获取服务器端时间的方法
摘要:用js做时间校正,获取本机时间,是存在bug的。使用js也可获取到服务器时间,原理是使用ajax请求,返回的头部信息就含有服务器端的时间信息...

用js做时间校正,获取本机时间,是存在bug的。

使用js也可获取到服务器时间,原理是使用 ajax请求,返回的头部信息就含有服务器端的时间信息,获取到就可以了。以下:

1、依赖jQuery

代码:

function getServerDate(){ return new Date($.ajax({async: false}).getResponseHeader("Date")); }

以上函数返回的就是一个Date对象,注意在使用ajax时必须同步,要不然无法返回时间日期。

无需填写请求链接;

如果服务器时间和本地时间有时差,需要做校正。

2、原生

代码:

function getServerDate(){ var xhr = null; if(window.XMLHttpRequest){ xhr = new window.XMLHttpRequest(); }else{ // ie xhr = new ActiveObject("Microsoft") } xhr.open("GET","/",false)//false不可变 xhr.send(null); var date = xhr.getResponseHeader("Date"); return new Date(date); }

同样返回的是一个Date对象,xhr.open()必须使用同步;

无需填写请求链接;open,send,和getResponseHeader 必须按序编写。

如需使用异步请求,可监听onreadystatechange状态来做不同的操作。

代码如下:

function getServerDate(){ var xhr = null; if(window.XMLHttpRequest){ xhr = new window.XMLHttpRequest(); }else{ // ie xhr = new ActiveObject("Microsoft") } xhr.open("GET","/",true); xhr.send(null); xhr.onreadystatechange=function(){ var time,date; if(xhr.readyState == 2){ time = xhr.getResponseHeader("Date"); date = new Date(time); console.log(date); } } }

使用异步不是很方便返回时间。

这里的readyState有四种状态,方便做不同处理:

0: 请求未初始化

1: 服务器连接已建立

2: 请求已接收

3: 请求处理中

4: 请求已完成,且响应已就绪

失败状态,status的值:

200: "OK"

404: 未找到页面

以上所述是小编给大家介绍的JavaScript获取服务器端时间的方法,希望对大家有所帮助,如果大家有任何疑问请给我们留言,小编会及时回复大家的。在此也非常感谢大家对查字典教程网的支持!

【JavaScript获取服务器端时间的方法】相关文章:

理解javascript定时器中的单线程

Javascript事件触发列表与解说

JavaScript中关联原型链属性特性

JavaScript获得url查询参数的方法

简述JavaScript中正则表达式的使用方法

JavaScript中的substr()方法使用详解

javascript实现获取服务器时间

JavaScript每天定时更换皮肤样式的方法

JavaScript容易犯错的九个陷阱

通过JavaScript脚本复制网页上的一个表格

精品推荐
分类导航