JQGrid Toolbar Search: поиск по нескольким словам для столбца
Я использую панель инструментов поиска. Можете ли вы найти несколько слов для столбца? Разделитель - это пробел, и поиск следует выполнять с помощью оператора Like. В результате поиск должен возвращать все строки, которые встречали все слова в строке поиска, независимо от того, в каком порядке они идут в поле строки. Например, есть столбец "Название продукта", я хочу найти все строки, в которых название продукта содержит слово "рычаг" и содержит слово "слева".
1 ответ
Интересный вопрос!
Я создал демо, которое демонстрирует, как реализовать поиск по нескольким словам:
Соответствующий код:
$grid.jqGrid('filterToolbar', {
stringResult: true,
defaultSearch: "cn",
beforeSearch: function () {
modifySearchingFilter.call(this, ' ');
}
});
где modifySearchingFilter
Я определил таким образом:
var modifySearchingFilter = function (separator) {
var i, l, rules, rule, parts, j, group, str,
filters = $.parseJSON(this.p.postData.filters);
if (filters && typeof filters.rules !== 'undefined' && filters.rules.length > 0) {
rules = filters.rules;
for (i = 0; i < rules.length; i++) {
rule = rules[i];
if (rule.op === 'cn') {
// make modifications only for the 'contains' operation
parts = rule.data.split(separator);
if (parts.length > 1) {
if (typeof filters.groups === 'undefined') {
filters.groups = [];
}
group = {
groupOp: 'OR',
groups: [],
rules: []
};
filters.groups.push(group);
for (j = 0, l = parts.length; j < l; j++) {
str = parts[j];
if (str) {
// skip empty '', which exist in case of two separaters of once
group.rules.push({
data: parts[j],
op: rule.op,
field: rule.field
});
}
}
rules.splice(i, 1);
i--; // to skip i++
}
}
}
this.p.postData.filters = JSON.stringify(filters);
}
};
ОБНОВЛЕНИЕ: Free jqGrid поддерживает пользовательскую операцию поиска с фильтрацией, что упрощает реализацию таких сценариев, как указано выше.