django html 刷新列表,在Django中重新加载表数据而无需刷新页面

小编典典

您可以使用setInterval,jQuery AJAX以及view:

您的HTML

Reg.nr.MärkeModell

{% for i in order %}

{% if i.order_booked %}

{% else %}

{% endif %}

{{ i.regnr|upper }}{{ i.brand|capfirst }}{{ i.brand_model|capfirst }}

{% endfor %}

JS

var append_increment = 0;

setInterval(function() {

$.ajax({

type: "GET",

url: {% url 'get_more_tables' %}, // URL to your view that serves new info

data: {'append_increment': append_increment}

})

.done(function(response) {

$('#_appendHere').append(response);

append_increment += 10;

});

}, 10000)

视图

def get_more_tables(request):

increment = int(request.GET['append_increment'])

increment_to = increment + 10

order = Order.objects.filter(owner=request.user).order_by('-id')[increment:increment_to]

return render(request, 'get_more_tables.html', {'order': order})

get_more_tables.html

{% for i in order %}

{% if i.order_booked %}

{% else %}

{% endif %}

{{ i.regnr|upper }}{{ i.brand|capfirst }}{{ i.brand_model|capfirst }}

{% endfor %}

然后只需确保将新视图添加到您的视图中urls.py

(确保它具有name='get_more_tables',或JS中的任何名称url:)

它的作用是使用setIntervalJS函数,GET每10000毫秒(10秒)向服务器中的视图发出AJAX请求。然后,该视图使用此新上下文呈现一个单独的HTML文件,并将其作为response回发送到原始HTML页面。全新response然后appended通过jQuery您的餐桌。每次发生此循环时,切片都会递增,因此您不会从获得相同的结果Order。

请记住,这将不停地循环,因此,如果要结束它,则必须将代码添加到JS以setInterval在最后一个响应返回为空时停止。

2020-07-26

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值