阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Django+Ajax异步刷新/定时自动刷新实例

31次阅读
没有评论

共计 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 部分的数据,进行展示

Django+Ajax 异步刷新 / 定时自动刷新实例

感兴趣的小伙伴可以参看,也希望有想法的小伙伴,评论区多多发表意见!!!

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计1280字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中