0

我有一个可见的表格行,其中包含一个带有“time-col”类的表格单元格。事实上,我有不止一个,父行的可见性是动态的。

我正在尝试用数字字符串(即 3、4 等)替换月份的三个字符串表示(即 MAR、APR 等)。

根据我虚弱的头脑,以下应该有效:

$('tr:visible .time-col').each(function() {
    // convert month string to numerical representation
    var monthStr = $(this).text().match(/[^\/]*/)[0];
    var months = { 'JAN': '1', 'FEB': '2','MAR': '3','APR': '4','MAY': '5','JUN': '6','JUL': '7','AUG': '8','SEP': '9','OCT': '10','NOV': '11','DEC': '12' };
    var month = months[monthStr];
    $(this).text( $(this).text().replace(monthStr, month) );
});

但结果将正确的字符串替换为“未定义”。现在,如果我替换最后一行:

$(this).text( $(this).text().replace(monthStr, month) );

和:

$(this).text(month);

我得到了相应表格单元格中显示的正确数字(即 3、4 等)。

是什么导致 Stack Overflow?¿

4

2 回答 2

2

$(this).text()返回一个字符串。修改该字符串不会触及原始字符串。

要修改文本,请设置元素的文本:

var text = $(this).text();
$(this).text(text.replace(monthStr, month));

此外,.replace()将字符串作为第一个参数仅替换字符串的第一个实例。您必须使用正则表达式一次替换所有出现的事件。

于 2013-03-26T21:05:56.230 回答
0

令人惊讶的是,我自己解决了这个问题。问题是,无论出于何种原因,JavaScript 都没有像我预期的那样工作,它决定不在我的月份对象中给我的数字字符串一个数据类型。

改变:

var month = months[monthStr]

至:

var month = months[monthStr].toString();

解决了问题!

于 2013-03-27T00:31:12.520 回答