源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

JavaScript获取服务器端时间的方法

  • 时间:2022-05-26 23:42 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:JavaScript获取服务器端时间的方法
用js做时间校正,获取本机时间,是存在bug的。 使用js也可获取到服务器时间,原理是使用 ajax请求,返回的头部信息就含有服务器端的时间信息,获取到就可以了。以下: [b]1、依赖jQuery[/b] 代码:
function getServerDate(){
return new Date($.ajax({async: false}).getResponseHeader("Date"));
}
以上函数返回的就是一个Date对象,注意在使用ajax时必须同步,要不然无法返回时间日期。 无需填写请求链接; 如果服务器时间和本地时间有时差,需要做校正。 [b]2、原生[/b] 代码:
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);
}
}
}
使用异步不是很方便返回时间。 [b]这里的readyState有四种状态,方便做不同处理:[/b] 0: 请求未初始化 1: 服务器连接已建立 2: 请求已接收 3: 请求处理中 4: 请求已完成,且响应已就绪 失败状态,status的值: 200: "OK" 404: 未找到页面 以上所述是小编给大家介绍的JavaScript获取服务器端时间的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部