Я использую плагин jQuery DataTables в своем приложении, и многие строки и фильтры моей таблицы содержат специальные символы, в частности амперсанд (& ) в них. Когда я пытаюсь отфильтровать эти столбцы, все записи исчезают, и отображается «соответствующие записи не найдены».
Я пробовал кодировать (т.е. htmlspecialchars) и декодировать (т.е. htmlspecialchars_decode) строки до того, как они будут напечатаны на странице, но ни один из них не работает.
Пример: http://jsfiddle.net/gkdcZ/3/
Любые идеи, почему это может происходить, и как я могу это исправить?
HTML:
<select id="filter_col_1" name="filter_col_1">
<option value="">Select</option>
<option value="A&B">A&B</option>
<option value="C">C</option>
<option value="D">D</option>
</select>
<tr>
<td>A&B</td>
<td>Jones, Brandon</td>
<td>01/02/2003</td>
</tr>
JavaScript:
$("#filter_col_1").change( function() {
$('#results').dataTable().fnFilter(
'\\b' + $("#filter_col_1").val() + '\\b',
1,
true,
false
);
} );
ОБНОВЛЕНИЕ №1: проблема возникает только при ограничении столбца. См. API DataTables. Работает нормально, когда для параметра установлено значение «null». http://jsfiddle.net/gkdcZ/4/
ОБНОВЛЕНИЕ №2: немного ближе. Добавление функции замены объектов HTML работает для определенных символов (например, амперсанд), но не работает для других символов (например, восклицательных и вопросительных знаков). См. http://jsfiddle.net/cz6Bs/4/.
'\\b' + htmlEntities($('#filter_col_1').val()) + '\\b'
function htmlEntities(str) {
return String(str).replace(/&/g, '&')
.replace(/</g, '<')
.replace(/>/g, '>')
.replace(/"/g, '"');
}