首先,我是 Django 新手,并且对 AJAX 和 jQuery 几乎完全不熟悉。我在本地开发。
所以我试图实现一个 HTML 表,在 AJAX 的帮助下每 X 秒动态刷新一次(没有页面刷新),但我似乎无法让我的代码工作。我已经使用过这个问题中提供的示例:https://stackoverflow.com/a/34775420/6724882
(如果我有足够的代表,我要么回答这个问题,要么通过聊天寻求帮助,但我还没有那么奢侈)
我已经尝试让它工作 10 多个小时了,我开始感到无助。我一直在疯狂地搜索网络,但我对所有不同的方法感到不知所措,每个问题和答案似乎要么已经有太多年头了,要么只是与我的应用程序无关。
目前,该表在第一个查询中工作正常,它显示对象 Kala,rivinumero = 1(英文行号)。
所以,我有几个问题。
- 我应该将脚本包含在其自己的单独文件中,而不是包含在
HTML 文件(在我的例子中为 displaykala.html)。如果是这样,该文件应该是
在 static/js 文件夹中,还是其他地方?
- 我是否需要单独包含 AJAX/JS 才能使脚本正常工作?
- 我明显做错了什么,还是我提供的问题的答案是错误的?
displaykala.html(与脚本在同一文件中)
{% load static %}
{% include 'loginbar.html' %}
{% include 'nav.html' %}
<html>
<head>
<title>Display</title>
<link rel="stylesheet" type="text/css" href="{% get_static_prefix %}css/style.css">
</head>
<body>
<h1>Display</h1>
<table id="_appendHere" class="table table-striped table-condensed">
<tr>
<th>Id</th>
<th>Nimi</th>
<th>Latnimi</th>
</tr>
{% for kala in kalat %}
<tr>
<td>{{kala.rivinro}}</td>
<td>{{kala.tuote}}</td>
<td>{{kala.latinalainen_nimi}}</td>
</tr>
{% endfor %}
</table>
</body>
</html>
<script>
var append_increment = 0;
setInterval(function() {
$.ajax({
type: "GET",
url: {% 'get_more_tables.html' %}, // URL to your view that serves new info
data: {'append_increment': append_increment}
})
.done(function(response) {
$('#_appendHere').append(response);
append_increment += 10;
});
}, 1000)
</script>
获取更多表.html
{% load static %}
{% for kala in kalat %}
<tr>
<td>{{ kala.rivinro }}</td>
<td>{{ kala.tuote }}</td>
<td>{{ kala.latinalainen_nimi }}</td>
</tr>
{% endfor %}
views.py
from django.shortcuts import render
from adminside.models import Kala
from adminside.models import Liha
from django.contrib.auth.decorators import login_required
# Create your views here.
def index(request):
return HttpResponse("Index")
@login_required
def displaykala(request):
kalat = Kala.objects.filter(rivinro=1)
return render(request, 'displaykala.html', {'kalat': kalat})
@login_required
def get_more_tables(request):
increment = int(request.GET['increment'])
increment_to = increment + 10
kalat = Kala.objects.filter(rivinro=2)[increment:increment_to]
return render(request, 'get_more_tables.html', {'kalat': kalat})
urls.py(应用程序文件夹中的一个)
urlpatterns = [
url(r'^$', views.index, name='index'),
url(r'^displayk$', views.displaykala, name='displayk'),
url(r'^get_more_tables', views.get_more_tables, name='get_more_tables'),
]
如果代码中存在“是的,我尝试这样做”之类的愚蠢实验,我很抱歉。