var filters_used = new Array();
$('#filter-text').keyup(function(k) {
$('#error').html('');
if (k.keyCode == 13) {
$('#add-filter').click();
}
});
function reg_remove() {
$('.remove-filter').click(function() {
console.debug("remove-filter.click()");
var col = $(this).children('td:nth-child(2)').html();
var index = $.inArray(col, filters_used);
filters_used.splice(index, 1);
$(this).parents('.filter').remove();
return false;
});
}
function check_value() {
var flag = true;
var value = $('#filter-text').val();
var col = $('#filter-type').val();
var reg = /[^0-9a-zA-Z\s\-]/;
if (value.match(reg) || value.trim() === "") {
flag = false;
$('#error').html('Only letters, numbers, spaces, and dashes (-) are allowed.');
} else if ($.inArray(col, filters_used) >= 0) {
flag = false;
$('#error').html('That column is already being filtered.');
}
return flag;
}
$('#add-filter').click(function() {
if (check_value()) {
var value = $('#filter-text').val();
var col = $('#filter-type').val();
$('#filter-text').val('');
appendstr = '<tr class="filter"><td>' + value + '</td><td>' + col + '</td><td>' + '<a href="" class="remove-filter">Remove</a></td></tr>';
$('#filter-form').after(appendstr);
filters_used.push(col);
reg_remove();
//queryDB();
}
});
function get_filters() {
}?
链接到包含我的代码的小提琴我
试图让用户创建一个过滤器列表,本质上。添加它们似乎工作正常,但是 remove() 函数仅在只有一个过滤器项时才能正常工作。如果您创建第一个,然后单击底部项目上的删除,该项目的 onclick() 函数将被调用两次,我终生无法弄清楚为什么。