1

环境:Win 10 Pro、Chrome 85、luxon 1.25.0

我最终要实现的是:在 ASP.Net/c# 应用程序中,不断地向用户显示会话超时之前的时间量。因为服务器和客户端可能位于不同的时区,所以我需要每个时区的 UTC 偏移量。客户的偏移量很容易得到。要查找服务器的偏移量(参考下面的代码片段):服务器代码将页面上次加载时间放入 lblLastLoaded。对象 dto 接收解析的日期部分,包括 dto.offset ,我认为它应该以分钟表示。随后对 luxon.DateTime.fromObject(dto) 的调用失败:pst 未定义。当我没有设置 dto.offset 时(通过在下面的代码中注释掉 4 行) pst 成功获取服务器时间,但没有偏移量;luxon 似乎使用了我的本地系统的偏移量,即 -7 小时。

    <script>
        function r4onload() {
            // Get server time:
            var st = document.getElementById('lblLastLoaded').innerHTML;
            //             Date       Time     Offset
            // st has form YYYY/MM/dd HH:mm:ss -HH:mm
            //                       1         2
            //             012345678901234567890123456
            // For Example 2020/09/29 10:31:56 -07:00
            let dto = {};
            dto.year = Number(st.substring(0, 4));
            dto.month = Number(st.substring(5, 7));
            dto.day = Number(st.substring(8, 10));
            dto.hour = Number(st.substring(11, 13));
            dto.minute = Number(st.substring(14, 16));
            var offsetHour = Number(st.substring(20, 23)); //                        works if these 4 lines are commented out
            var offsetMinutes = Number(st.substring(24, 26)); //                     works if these 4 lines are commented out
            dto.offset = offsetHour * 60 + Math.sign(offsetHour) * offsetMinutes; // works if these 4 lines are commented out
            // dto.offset is correctly calculated to -420 minutes //                 works if these 4 lines are commented out
            var pst = luxon.DateTime.fromObject(dto);
            // pst is undefined at this point -- why??
            // If I do not include anything about offset above (comment out the 4 lines 
            //    containing offsetHours, offsetMinutes, and dto.Offset, then pst comes out like this:
            //    2020-09-29T10:31:00.00000-07:00
            //    i.e., luxon used the offset -07:00 of my local system, not the one contained in variable st.
            document.getElementById('Parsed').innerHTML = pst;
            r4startTime();
        }
        function r4startTime() {
            var dt = luxon.DateTime.local();
            var h = dt.hour;
            var m = dt.minute;
            var s = dt.second;
            m = r4checkTime(m);
            s = r4checkTime(s);
            document.getElementById('CurrTime').innerHTML =
                h + ":" + m + ":" + s;
          var t = setTimeout(r4startTime, 2000);
        }
        function r4checkTime(i) {
          if (i < 10) {i = "0" + i};  // add zero in front of numbers < 10
          return i;
        }
    </script>

一个完整的 Visual Studio 2017 项目 DemoLuxon 与文件 Site.Master 中的上述代码片段在这里:https ://1drv.ms/u/s!AvoFL8QrGVaTsQvbaB8-Zh7GdloV?e=ODjZW5

如果上述方法很尴尬,我将不胜感激有关确定客户端/服务器偏移差异的更优雅方法的建议。

4

1 回答 1

1

我设计了一个解决方法如下,但原始问题尚未得到解答:

    <script>
        function r4onload() {
            var st = document.getElementById('lblLastLoaded').innerHTML;
            //             Date       Time     Offset
            // st has form YYYY/MM/dd HH:mm:ss -HH:mm
            //                       1         2
            //             012345678901234567890123456
            // For Example 2020/09/29 10:31:56 -07:00
            // Transform to ISO format:
            st = st.substring(0, 4) + '-' + st.substring(5, 7) + '-' + st.substring(8, 10)
                + 'T' + st.substring(11, 19) + ".000" + st.substring(20);
            document.getElementById('Xformed').innerHTML = st;
            var pst = luxon.DateTime.fromISO(st, { setZone: true });
            document.getElementById('Parsed').innerHTML = pst;
            r4startTime();
        }
        function r4startTime() {
            var dt = luxon.DateTime.local();
            var h = dt.hour;
            var m = dt.minute;
            var s = dt.second;
            m = r4checkTime(m);
            s = r4checkTime(s);
            document.getElementById('CurrTime').innerHTML =
                h + ":" + m + ":" + s;
          var t = setTimeout(r4startTime, 2000);
        }
        function r4checkTime(i) {
          if (i < 10) {i = "0" + i};  // add zero in front of numbers < 10
          return i;
        }
    </script>

即,首先将日期时间转换为 ISO 格式,然后使用 luxon.DateTime.fromISO。变量 pst 获取正确的日期时间值,包括偏移量。带有偏移量的 luxon.DateTime.fromObject 的问题仍未解决。

于 2020-10-17T20:07:21.593 回答