【发布时间】:2018-10-06 22:04:51
【问题描述】:
目前我正在构建一个通过 AJAX 更新主页数据的应用程序。 基于this 问题,我使用(参见下面的代码/1/)ajax 来刷新我的页面。我的另一个目标是从视图中捕获某些变量并用作 JS 变量。如果我在 AJAX 请求中仅使用 Django 模板变量,我的变量不会刷新。
第一次尝试:
Django 视图:
def fetch_data (request):
query_1=Objects.all()
query_2=Objects.all()
#From these queries I colect data and push them to lists.
context= {
'variable_1': variable_1,
'variable_2': variable_2,
'time_variable': time_variable #changing in every minute
}
return render(request, 'app/index.html', context)
AJAX:
这里我使用 AJAX 请求。我每分钟都运行它以将我的页面重新加载到我的页面中。我的问题是我想加载只是让我们说time_variable 在AJAX 中再次使用它。如果我在 AJAX 重新加载时像使用单个模板变量 ({{time_variale|safe}}) 一样使用它,我会一次又一次地获得相同的变量,而不是因为刷新而获得新变量。我如何捕获 Django 变量?
setInterval(function(){
if(new Date().getSeconds() === 0) {
$.ajax({
url:'{% url 'fetch_data' %}',
success: function (data){
$('body').html(data); #This working, the data refreshing
var="{{time_variable|safe}}"; #Here I always get the same in every minutes despite the variable get new value in every minute in the view.
}
});
}
},1000)
【问题讨论】:
-
我不明白为什么你会认为 JS 内部的硬编码值会因为 Ajax 调用而改变。
-
这只是一个想法,我分享了它,我意识到,它不起作用。你知道有什么建议吗?
-
{{time_variable|safe}}在页面呈现时计算,而不是在运行 javascript 时计算。您需要将新的时间变量与您的 json 一起传回 -
您正在调用 AJAX 请求以仅刷新 html 模板的正文,但它不会刷新您的变量。为了也刷新变量,您可以创建另一个视图,该视图将以 JSON 格式返回您的变量。然后在您的 javascript 部分中,您可以创建另一个 AJAX 请求,该请求将调用 JSON-view 并从中获取变量的值。
标签: javascript python ajax django django-templates