python后端如何向前端展示任务进度,写一个案例功能代码
时间: 2024-04-29 10:27:08 浏览: 206
好的,可以为您提供一个案例功能代码。
首先,我们需要在后端编写一个任务方法,并在任务执行过程中定期更新进度信息。以 Django 框架为例,下面是一个简单的任务方法:
```python
import time
def long_task(request):
# 任务开始时,将任务信息存储在 session 中
request.session['task_progress'] = 0
for i in range(10):
# 模拟耗时操作
time.sleep(1)
# 定期更新进度信息
request.session['task_progress'] = (i + 1) * 10
# 任务完成,清除进度信息
del request.session['task_progress']
return HttpResponse('Task completed!')
```
在前端页面中,我们可以使用 AJAX 定时向后端查询任务进度并更新页面。下面是一个简单的页面示例:
```html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Task Progress</title>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
</head>
<body>
<h1>Task Progress:</h1>
<div id="progress">Waiting for task to start...</div>
<script>
$(document).ready(function() {
setInterval(function() {
$.ajax({
url: '/long_task_status/',
success: function(data) {
$('#progress').text(data);
}
});
}, 1000);
});
</script>
</body>
</html>
```
在这个页面中,我们使用 jQuery 定时向 `/long_task_status/` URL 查询任务进度信息,并将结果更新到页面上的进度条中。下面是一个简单的 Django 视图函数 `/long_task_status/`,用于返回任务进度信息:
```python
from django.http import JsonResponse
def long_task_status(request):
progress = request.session.get('task_progress')
if progress is not None:
return JsonResponse({'progress': progress})
else:
return JsonResponse({'error': 'No task in progress'})
```
这段视图函数会查询 session 中是否存在任务进度信息,并返回对应的 JSON 数据。在前端 AJAX 成功访问后,会将任务进度信息更新到页面上的进度条中。
以上代码仅作为示例,具体实现还需要根据具体的应用场景来调整。
阅读全文