我们有一个课程表,在东部时间看起来如下(前 4 行)。
Sat 12/08/2012 1:00-3:30 PM
Mon 12/10/2012 9:30-12:00 AM
Wed 12/12/2012 9:30-12:00 AM
Sat 12/15/2012 1:00-3:30 PM
您可以选中单选按钮并选择不同的时区。例如,如果您选择中央时间,您应该会在更改时看到:
Sat 12/08/2012 12:00-2:30 PM
Mon 12/10/2012 8:30-11:00 AM
Wed 12/12/2012 8:30-11:00 AM
Sat 12/15/2012 12:00-2:30 PM
相反,您会看到:
Wed 30/05/2012 8:09 am-11:09 pm
Sat 00/08/2012 12:09-2:09 pm
Mon 30/10/2012 8:09 am-11:09 pm
Wed 30/12/2012 8:09 am-11:09 pm
部分原因可能是日期格式问题,但该格式在其他地方可以正常工作。我认为主要问题在于更改循环(每个),它抓取每行的三个部分(0 = 日期,1 = 日期,2 = 时间(实际上被拆分为 0 和 1 的子数组用于开始和结束时间,午夜有一个特殊情况))应用新时区的时移,并构建新的行内容。我找不到出了什么问题。任何想法表示赞赏。(init vars 和其他最重要的东西被省略了):
$('.timezoneSel').click(function (evtObj) {
_curevtObj = evtObj;
_prevtmzObj = _curtmzObj;
$('input.timezoneSel[value="' + _curevtObj.target.value + '"]').each(function () {
$(this).attr('checked', true);
});
for (var x = 0; x < timezoneset.length; x++) if (timezoneset[x].abbr == _curevtObj.target.value) _curtmzObj = timezoneset[x];
$('table.TPR_tblcoursedetails').each(function (i, val) {
$(this).contents().find('tr').each(function (irow, vrow) {
isEvening = false;
$(this).contents().find('span').each(function (icol, vcol) {
switch (icol) {
case 0:
rowwday = vcol.innerHTML;
break;
case 1:
rowdate = vcol.innerHTML;
break;
case 2:
rowtime = vcol.innerHTML;
break;
}
});
isEvening = ((rowtime.indexOf(" PM") > -1) ? true : false);
rowtimearr = rowtime.split("-");
if (rowtimearr[0] == MidNiteStr) rowtimearr[0] = "12:00 AM";
if (rowtimearr[1] == MidNiteStr) rowtimearr[1] = "12:00 AM";
if (rowtimearr[0].indexOf(" AM") < 0 && rowtimearr[0].indexOf(" PM") < 0) rowtimearr[0] += isEvening ? " PM" : " AM";
newStartDate = new Date(rowdate + ' ' + rowtimearr[0]);
newEndDate = new Date(rowdate + ' ' + rowtimearr[1]);
newStartDateMsec = newStartDate.getTime() + ((_curtmzObj.offset - _prevtmzObj.offset) * msecPerHour);
newEndDateMsec = newEndDate.getTime() + ((_curtmzObj.offset - _prevtmzObj.offset) * msecPerHour);
newStartDate = new Date(newStartDateMsec);
console.log(newStartDate);
newEndDate = new Date(newEndDateMsec);
$(this).contents().find('span').each(function (icol2, vcol2) {
adjStartTimeTT = newStartDate.format('tt');
adjEndTimeTT = newEndDate.format('tt');
console.log(adjStartTimeTT, adjEndTimeTT);
switch (icol2) {
case 0:
vcol2.innerHTML = newStartDate.format("ddd");
break;
case 1:
vcol2.innerHTML = newStartDate.format("MM/dd/yyyy");
break;
case 2:
vcol2.innerHTML = ((adjStartTimeTT == adjEndTimeTT) ? newStartDate.format("h:mm") : newStartDate.format("h:mm tt")) + "-" + ((useMidNite && newEndDate.format("h:mm tt") == "12:00 AM") ? MidNiteStr : newEndDate.format("h:mm tt"));
break;
}
});
});
filledonce = false;
});