У меня есть массив строк в jQuery.У меня есть другой массив ключевых слов, которые я хочу использовать для фильтрации массива строк.
Мои два массива:
var arr = new Array("Sally works at Taco Bell", "Tom drives a red car", "Tom is from Ohio", "Alex is from Ohio");
var keywords = new Array("Tom", "Ohio");
Как я могу отфильтровать массив arr
, используя массив keywords
в jQuery?В этой ситуации он отфильтровывает «Салли работает в Taco Bell» и оставит все остальное.
Ниже приведен фактический код, который я использую.
var keywords= [];
var interval = "";
var pointer = '';
var scroll = document.getElementById("tail_print");
$("#filter_button").click(
function(){
var id = $("#filter_box").val();
if(id == "--Text--" || id == ""){
alert("Please enter text before searching.");
}else{
keywords.push(id);
$("#keywords-row").append("<td><img src=\"images/delete.png\" class=\"delete_filter\" /> " + id + "</td>");
}
}
);
$(".delete_filter").click(
function(){
($(this)).remove();
}
);
function startTail(){
clearInterval(interval);
interval = setInterval(
function(){
$.getJSON("ajax.php?function=tail&pointer=" + pointer + "&nocache=" + new Date(),
function(data){
pointer = data.pointer;
$("#tail_print").append(data.log);
scroll.scrollTop = scroll.scrollHeight;
});
}, 1000);
}
Цель всего этого - позволить пользователю фильтровать результаты журнала.Таким образом, пользователь выполняет действие, которое запускает startTail()
, а $.getJSON()
извлекает объект JSON, созданный функцией PHP, и печатает результаты.Работает без нареканий.Теперь я хочу дать пользователю возможность фильтровать входящие элементы.Пользователь нажимает кнопку фильтра, и jQuery берет текст фильтра и добавляет его в массив keywords
, затем data.log
из объекта JSON фильтруется с использованием массива keywords
и затем добавляется на экран.
У меня также есть функция удаления фильтра, которая не работает.Может быть, кто-то может помочь мне с этим.