django的搜索不能正常使用
def cs(request):da = {}
n = request.GET.get('q')
if n:
da["name"] = n
ss = models.Userinfo.objects.filter(**da)
print(ss)
前台输入对应的信息后台显示 对应的name的数据 正常不是应该显示id吗
且前台输入数据 其他不符合的数据还是在前台显示
————————————————————
html文件
{% extends 'rootyongh.html' %}
{% block b %}
<div class="bs-example" data-example-id="panel-without-body-with-table">
<div class="panel panel-default">
<!-- Default panel contents -->
<div class="panel-heading">用户信息
<form method="get">
<div class="input-group">
<input type="text" name="q" class="form-control" placeholder="Search for...">
</form>
<span class="input-group-btn">
<button class="btn btn-default" type="submit"><span class="glyphicon glyphicon-search" aria-hidden="true"></span></button>
</span>
</div><!-- /input-group -->
</div><!-- /.col-lg-6 -->
</div><!-- /.row -->
<!-- Table -->
<table class="table">
<tr>
{% for s in deat %}
<tr>
<td align="left">{{ s.id }}</td>
<td align="left">{{ s.name }}</td>
<td align="left">{{ s.password }}</td>
<td align="left">{{ s.age }}</td>
<td align="left">{{ s.daa }}</td>
<td>
<a href="http://127.0.0.1:8000/edit/{{ s.id }}/edit">编辑</a>
</td>
<td>
<a href="http://127.0.0.1:8000/delete/{{ s.id }}/delete"} >删除</a>
</tr>
{% endfor %}
</table>
</tr>
</tbody>
</table>
</div>
</div>
{% endblock %}
从您提供的代码来看,您的问题主要有以下两点:
1. 后台显示对应的 `name` 数据而不是 `id`。
2. 输入不匹配的数据,前端依然显示了所有的数据。
针对这两个问题,我有以下建议:
问题1:后台显示对应的 `name` 数据而不是 `id`
您的代码中使用了 `print(ss)` 输出查询结果。查询结果 `ss` 是一个包含 `Userinfo` 对象的 QuerySet,这意味着每个元素都是一个完整的 Userinfo 对象,包含所有属性(id、name、password 等)。要仅显示查询结果的 `id`,您可以在 `print` 语句中使用列表推导式提取每个对象的 `id`。修改如下:
print()
问题2:输入不匹配的数据,前端依然显示了所有的数据
这个问题的原因是您在搜索时没有更新 `deat` 变量,而前端代码中的 `deat` 变量用于渲染表格数据。您需要将查询结果 `ss` 传递给前端模板以便在表格中渲染正确的数据。修改如下:
from django.shortcuts import render
def cs(request):
da = {}
n = request.GET.get('q')
if n:
da["name"] = n
ss = models.Userinfo.objects.filter(**da)
print()
return render(request, 'your_template_name.html', {'deat': ss})
这里,你需要将 `'your_template_name.html'` 替换为您实际使用的模板文件名。
现在,当用户输入搜索关键字时,前端页面应该仅显示与关键字匹配的数据。如果没有输入关键字,页面将显示所有数据。
页:
[1]