0

一段时间以来,我一直在为此挠头。我在UI 的前端使用 daterangepicker.js ( http://tamble.github.io/jquery-ui-daterangepicker/ )。我的实现非常基本,可以在下面找到。问题是每当我使用 moment.unix() 转换扩展时间时,时间戳都会在输入日期前一小时返回

<script type="text/javascript">
    $("#date-range").daterangepicker({
        datepickerOptions : {
            numberOfMonths : 1,
        },
        presetRanges: [{
           text: 'Last 7 Days',
           dateStart: function(){return moment().subtract('days', 7)},
           dateEnd: function() { return moment() }
        },{
           text: 'Last 30 Days',
           dateStart: function(){return moment().subtract('days', 30)},
           dateEnd: function() { return moment() }
        },{
           text: 'Last 3 months',
           dateStart: function(){return moment().subtract('days', 90)},
           dateEnd: function() { return moment() }
        },{
           text: 'Last 6 months',
           dateStart: function(){return moment().subtract('days', 180)},
           dateEnd: function() { return moment() }
        },{
           text: 'This Year',
           dateStart: function(){return moment().startOf('year')},
           dateEnd: function() { return moment() }
        }],
        change:function(event, data){

            // gets inputted dates
            var inputData = $('#date-range').daterangepicker('getRange');

            console.log(inputData);

            // formats dates into unix time stamps
            var start = moment(inputData.start).unix();
            var end   = moment(inputData.end).unix();

            console.log(start);

            // get current URL of the page (without query string)
            var currentUrl = location.protocol+'//'+location.host+location.pathname;

            // create new url
            var newUrl = currentUrl+'?start='+start+'&end='+end;

            // redirect to new URL
            //window.location.href = newUrl;
        }
    });
</script>

这里有一个示例:正如您所见,传递给我的时刻 js 的开始标记是 2017 年 10 月 2 日星期一午夜(这是正确的,反映了我在 UI 中选择的内容)

开始时间:2017 年 10 月 2 日星期一 00:00:00 GMT+0100(GMT 夏令时间){}

当我使用

var start = moment(inputData.start).unix();

它转换为 1506898800,反映 10/01/2017 @ 11:00pm (UTC)

我试过moment().utc()。

这里有任何指示吗?

PS 我知道我可以在时间戳中添加 3600,但我不想这样做,因为我确定我错过了一些相对简单的东西。

谢谢

4

1 回答 1

1

首先,Mon Oct 02 2017 00:00:00 GMT+0100 (GMT Daylight Time)等于 Sun Oct 01 2017 23:00:00 GMT+0000 (UTC)转换为UTC时。

秒,.unix() 将返回 1970 年相对于UTC 时间的秒数。时间戳没有时区。

解决方案是将时区固定为指定的时区,并使用最安全的时区(UTC,无 DST 开关)来做到这一点。为此,请尝试在页面中包含moment-timezone并在初始化 datepicker 之前运行此代码一次:

moment.tz.setDefault("UTC"); 

这样,您的所有日期都将与 unix 时间戳兼容。

于 2017-11-15T04:51:14.130 回答