频道栏目
首页 > 程序开发 > web前端 > HTML/CSS > 正文
JS跨时区时间解决方案
2017-04-20 10:44:00           
收藏   我要投稿

JS跨时区时间解决方案:由于地球的物理运行规律,地球时间被划分有24个时区,每个时区间隔一个小时,所以经常国外出差的朋友们也会关注一下目的地的时区及当地时间。

当然不仅生活中会受时间的影响,对于WEB程序员开发者开发国际化项目时也会遇到不小的麻烦,比如公司WEB服务器在中国,要确保国外客户访问数据的正常与正确性,得考虑跨时区的问题。既要确保服务器时间的统一性,又要确保时间的重要性。

javaScript开发国际化项目有时也会遇到这个问题,以下为本人根据网络查询所得及结合自身项目情况所写的一个获取不同时区时间的函数方法。

    //得到标准时区的时间
    function getLocalTime(i) {
        //参数i为时区值数字,比如北京为东八区则输入8,西5输入-5,现默认东八区北京时间
        var i=i?parseFloat(i):8; 

        //得到本地时间
        var d = new Date();

        //得到1970年一月一日到现在的秒数
        var local = d.getTime();

        //本地时间与GMT时间的时间偏移差
        var offset = d.getTimezoneOffset() * 60000;

        //得到现在的格林尼治时间
        var utcTime = local + offset;

        return new Date(utcTime + 3600000 * i);
    }
    //转换服务器时区时间
    function formatTime(t,utc){
        //t传入的时间参数,utc传入的时区参数
        if(!t) return;

        //获取本地时间
        var d=new Date();

        //获得本地时区
        utc=utc?parseFloat(utc):d.getTimezoneOffset()/60;

        //格式化传入时间
        var time=new Date(t);

        //转换传入时间为本地时间(默认传入服务器时间为东八区时间)
        time.setHours(time.getHours()+(utc-8));

        //输出时间
        var yy=time.getFullYear();
        var MM=time.getMonth()+1;
        MM=MM<10?'0'+MM:MM;
        var dd=time.getDate();
        dd=dd<10?'0'+dd:dd;
        var hh=time.getHours();
        hh=hh<10?'0'+hh:hh;
        var mm=time.getMinutes();
        mm=mm<10?'0'+mm:mm;
        var ss=time.getSeconds();
        ss=ss<10?'0'+ss:ss;
        var date=yy+'-'+MM+'-'+dd+' '+hh+':'+mm+':'+ss;

        return date;
    }
点击复制链接 与好友分享!回本站首页
上一篇:npm模块(二)xls-to-json
下一篇:使用layui组件的小问题1.0,
相关文章
图文推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站