共计 1280 个字符,预计需要花费 4 分钟才能阅读完成。
导读 | AJAX 是前端技术的集合, 包括 JavaScript、XML、HTML、CSS 等, 下面这篇文章主要给大家介绍了关于 Django+Ajax 异步刷新 / 定时自动刷新的相关资料, 文中通过实例代码介绍的非常详细, 需要的朋友可以参考下 |
分享一下最近在学习 Django 过程中,遇到和解决的一些有趣的方法和问题
一、Django 是什么?
Django 也不用在过多的去介绍了。使用 python 进行 web 开发的基本上都在用着框架,反正大家都在用,哈哈哈
二、Ajax 异步刷新
1.jQuery 语法下的 Ajax 运用
代码如下(示例):
$.ajax( | |
{ | |
type:"GET", | |
url:"/ajax_loadavg", | |
dataType:"json", | |
success:function (data) {json_data = data} |
当然大家别忘了在页面引入 jQuery 的源
通过这种方式,可以实现异步数据更新,做到只刷新部分页面而不需要整个页面进行刷新!!!
2. 定时刷新页面的样例
这里面使用 chartist 响应式图标作为案例,设定每 15s 中对图表进行一次刷新。
HTML5 代码示例如下:
jQuery 代码示例如下:
setInterval(function () { | |
$.ajax( | |
{ | |
type:"GET", | |
url:"/ajax_loadavg", | |
dataType:"json", | |
success:function (data) { | |
json_data = data | |
data = {labels: [0, 10, 20, 30, 40, 50, 60], | |
series: [[1, 2, 3, 4, 0, 0, 0], | |
[0, 0, 0, 0, 0, 0, 0], | |
[0, 0, 0, 0, 0, 0, 0], | |
] | |
}; | |
options = { | |
height: 300, | |
showArea: true, | |
showLine: false, | |
showPoint: false, | |
fullWidth: true, | |
axisX: { | |
showGrid: false, | |
showLabel: false | |
}, | |
lineSmooth: false, | |
}; | |
new Chartist.Line('#headline-chart', data, options); | |
} | |
},15000) |
Django 视图(view)代码如下:
注意:此处只是展示 Ajax 与 Django 如何进行交互,Ajax 获取的 JSON 数据并未进行利用!
@csrf_exempt | |
def ajax_loadavg(request): | |
if request.method == 'GET': | |
context = {'output_loadavg':output_loadavg} | |
return HttpResponse(json.dumps(context)) |
url 配置
path('ajax_loadavg/', views.ajax_loadavg, name='ajax_loadavg'),
3. 展示效果
可以替换 series 部分的数据,进行展示
感兴趣的小伙伴可以参看,也希望有想法的小伙伴,评论区多多发表意见!!!
正文完
星哥玩云-微信公众号
