0

我们有一个课程表,在东部时间看起来如下(前 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;
    });
4

1 回答 1

0

好的,结果是这一行:

$('.TPR_tblcoursedetails').html($('.TPR_tblcoursedetails').html().replace(/ EST/g, ""));

它位于主循环之上,本身并没有循环。它只是抓取了一次 EST 并在整个过程中替换它,但它也使它下面的大循环做同样的事情,所以交互不正确。我们将其更改为:

$('.TPR_tblcoursedetails').each(function(iobj,vobj){
                vobj.innerHTML.replace(/ EST/g, "");
            });
于 2012-12-13T17:17:40.373 回答