我们有一个课程安排,在东部时间看起来像以下(前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;
});
答案 0 :(得分:0)
好的,所以事实证明这一行:
$('.TPR_tblcoursedetails').html($('.TPR_tblcoursedetails').html().replace(/ EST/g, ""));
在主循环之上的没有自行循环。它只是抓住EST一次并在整个过程中取代它,但它也使它下面的大循环做同样的事情,所以这种交互是不正确的。我们将其更改为:
$('.TPR_tblcoursedetails').each(function(iobj,vobj){
vobj.innerHTML.replace(/ EST/g, "");
});