27
我正在使用yadcf和select2的DataTables的服务器端实现来实现附加功能。用于填充通过Ajax请求获取到Django视图的表的数据,以及select2自动完成功能的数据,但是来自单独的Django视图。当搜索返回无结果时,Select2过滤器值消失
我的问题是下面的问题。如果搜索查询不返回结果,则select2搜索字段中的值将消失并且无法在DataTable中重置 - 您必须改为刷新页面。非select2字段中的值保持可见并且可以重置。
有问题的列中的过滤器类型是multi_select
,选择类型为select2
。 无问题列中的过滤器类型为range_date
和range_date
,使用bootstrap-datetimepicker
作为日期选择器类型。
以下是我的select2列参数。
{
"column_number": 3,
"filter_type": "multi_select",
"select_type": "select2",
"select_type_options": {
dropdownCssClass : 'bigdrop',
multiple: true,
minimumInputLength: 1,
ajax: {
url: '{% url 'ffTestApp:searchData' 'product' %}',
delay: 250,
dataType: 'json',
data: function (params) {
return {
q: params.term,
v: yadcf.exGetColumnFilterVal(table,4),
s: yadcf.exGetColumnFilterVal(table,5)
};
},
processResults: function (data, params) {
params.page = params.page || 1;
return {
results: data.items
};
},
},
escapeMarkup: function (markup) { return markup; },
templateResult: function(data) {
return data.id;
},
templateSelection: function(data) {
return data.id;
}
}
}
下面是我的Django视图,用于提供自动完成功能。
def searchData(request, column):
try:
q = request.GET.getlist('q')[0]
except:
pass
else:
if q != "":
try:
products = request.GET.getlist('p[]')
except:
pass
else:
product_q = list()
for p in products:
product_q.append("p.name='{}'".format(p))
if len(product_q)>0:
product_q = "({}) AND ".format(" OR ".join(product_q))
else:
product_q = ""
try:
versions = request.GET.getlist('v[]')
except:
pass
else:
version_q = list()
for v in versions:
version_q.append("tp.version='{}'".format(v))
if len(version_q)>0:
version_q = "({}) AND ".format(" OR ".join(version_q))
else:
version_q = ""
try:
serials = request.GET.getlist('s[]')
except:
pass
else:
serial_q = list()
for v in serials:
serial_q.append("s.serial='{}'".format(v))
if len(serial_q)>0:
serial_q = "({}) AND ".format(" OR ".join(serial_q))
else:
serial_q = ""
autoComplete = connection.cursor()
if column == "product":
query = "SELECT DISTINCT p.name FROM ffTestApp.ffTestApp_product AS p INNER JOIN ffTestApp.ffTestApp_testprogram AS tp " \
"ON tp.product_id=p.id INNER JOIN ffTestApp.ffTestApp_session AS s ON s.test_program_id = tp.id " \
"WHERE {1}{2}p.name REGEXP '{0}' ORDER BY p.name ASC;".format(q, version_q, serial_q)
elif column == "version":
query = "SELECT DISTINCT tp.version FROM ffTestApp.ffTestApp_testprogram AS tp INNER JOIN ffTestApp.ffTestApp_session AS s " \
"ON s.test_program_id=tp.id INNER JOIN ffTestApp_product AS p ON tp.product_id=p.id WHERE {1}{2}tp.version REGEXP '{0}'" \
" ORDER by tp.version;".format(q, product_q, serial_q)
elif column == "serial":
query = "SELECT DISTINCT s.serial FROM ffTestApp.ffTestApp_session AS s INNER JOIN ffTestApp_testprogram AS tp ON s.test_program_id=tp.id" \
" INNER JOIN ffTestApp_product AS p ON tp.product_id=p.id WHERE {1}{2}" \
"s.serial REGEXP '{0}' ORDER BY s.serial;".format(q, product_q, version_q)
elif column == "status":
query = "SELECT DISTINCT final FROM ffTestApp.ffTestApp_session WHERE final REGEXP '{0}' ORDER BY final;".format(q)
autoComplete.execute(query)
m = []
for i in autoComplete.fetchall():
value = dict()
value["id"] = i
m.append(value)
results = {"items": m}
return JsonResponse(results, safe=False)
谢谢。
离不开一个链接到一个测试页面的帮助,您可以尝试使用AJAX源(从文件)复制和其托管在任何JS操场网站 – Daniel
嘿丹尼尔,这个错误似乎也存在于你的一个例子中,并与之相关联。请尝试以下操作: 在“某些数据”列中搜索“某些数据11”。 在值列中搜索'b_value'。 您会看到“某些数据”列中的搜索参数消失。 http://yadcf-showcase.appspot.com/cumulative_filtering.html –
'b_value'(和其他的'a_value,e_value'除外)不应该存在,因为它的'cumulative_filtering'模式...将看到为什么是... – Daniel