上次的AJAX定时刷新多ID不正确,这次请教了高手之后补全

关键是setInterval无法传递参数,所以用了匿名函数再包裹一下就好了。

//重置发布进度
    function resetPercent(id_data){
        $.ajax({
              url:‘/autodeploy/reset_percent/‘ + id_data,
              success: function(json){
                },
            });
    };
    //间隔刷新,显示百分比,AJAX调用rest_framework框架
    var _interval = {};

    function showPercent(id_data){
        //var _interval;
        var percent_value;
        var id_subserver = id_data.split("-")[0]

        $.getJSON("/api/subserver/" + id_subserver,
            function(data,state){
                if (state == ‘success‘) {
                    percent_value_array = data.deploy_status.split(",");
                    percent_value = percent_value_array[0];
                    cmd_value = percent_value_array[1];
                    $(‘#‘ + id_data).html("<div class=‘uk-progress uk-progress-striped uk-progress-active‘><div class=‘uk-progress-bar‘ style=‘width: " + percent_value + "%;‘>" +  cmd_value + ‘ ‘ + percent_value + "%</div><i class=‘uk-icon-cog uk-icon-spin‘></i></div>");
                     console.log(percent_value[0])
                        if ( percent_value != 100 ){
                            //_interval = setInterval(showPercent(id_data), 3000);
                        } else {
                             clearInterval(_interval[id_data]);
                             $(‘#‘ + id_data).html("<div class=‘uk-progress uk-progress-striped uk-progress-success‘><div class=‘uk-progress-bar‘ style=‘width: " + percent_value + "%;‘>100%</div></div>");
                        };

                    };
            }
        );
    };

    $(".btn-multi-deploy").click(function(){
          var deploypool_id =  $(this).attr("deploypool_id")
          var group_data = $("#deploy-form" + deploypool_id).serialize()
          var deploy_type = $(this).attr("deploy_type")
          var _self = this;

          console.log(deploypool_id, group_data)

          //因为涉及到模态对话态中的AJAX输出ID定位,所以用了两个数组来重置更新进度和刷新百分比。可以优化。
          var id_array = []
          var id_s_array = []
          var group_array = group_data.split("&");
          for (var key_data in group_array) {
            if (group_array[key_data].indexOf("select-deployversion") != -1) {
                deploy_id = group_array[key_data].split("=")[1]
            };
            if (group_array[key_data].indexOf("check-server") != -1) {
                id_s_array.push(group_array[key_data].split("=")[1])
                id_array.push(group_array[key_data].split("=")[1] + "-" +deploy_id)

            };
          };

          promiseDEPLOY = $.ajax({
            url:‘{% url "autodeploy:group-cmd" %}‘,
            type: ‘post‘,
            data:{
                group_data: group_data,
                deploy_type: deploy_type,
            },
            dataType: ‘json‘,
            beforeSend: function(){
                result_output = $(_self).siblings("p.result_output");
                result_output_desc = $(_self).siblings("p.result_output_desc");
                $(_self).attr(‘disabled‘,"true");
                $(_self).append(" <i class=‘uk-icon-cog uk-icon-spin‘></i>");
                result_output_desc.append(" <strong>集群发布中,请耐心等候....</strong>");
                // result_output.html("<div >集群发布中,请耐心等候....</div>");
                //发送前重置
        for( index=0;index < id_s_array.length;index++){
                    resetPercent(id_s_array[index]);
                }
            },
            success: function(json){
                $(_self).children(‘i‘).remove();
                $(_self).append(" <i class=‘uk-icon-check‘></i>")
                result_output_desc.append("<span class=‘uk-text-success‘><i class=‘uk-icon-check‘></i></span>");
                result_output_desc.append("<span class=‘uk-text-success‘>异步队列分发完成,每个服务器开始更新。</span>");
                //发送后获取进度

         for( index=0;index < id_array.length;index++){
            var key = id_array[index];
                    //_interval = setInterval(function(){showPercent(key)}, 3000);
            _interval[key] = setInterval(function(){showPercent(key);}, 3000);
                }
        },
            error: function(){
                result_output_desc.append("<span class=‘uk-text-muted‘><br>服务器内部错误 </span>");
                result_output_desc.append("<span class=‘uk-text-danger‘><i class=‘uk-icon-remove‘></i></span>");
                $(_self).children(‘i‘).remove();
                result_output.html("<div ></div>");
            },
            complete: function(){
            }
        });/* end cmd-run stop */
    });
时间: 2025-01-06 02:07:40

上次的AJAX定时刷新多ID不正确,这次请教了高手之后补全的相关文章

jQuery实现AJAX定时刷新局部页面实例

本篇文章通过两种方法实例讲解ajax定时刷新局部页面,当然方法有很多种,也可以不使用ajax来刷新页面,可以使用jquery中的append来给指定内容加东西, 但是都不太实用,最实用的方法还是ajax加载数据了. 方法一: 局部刷新我们讲述到最多的是ajax 了,当然也可以不使用ajax来刷新页面了,我们可以使用jquery中的append来给指定内容加东西了,当然最实用的还是ajax加载数据了. 例子,定时局部刷新 定时局部刷新用到jQuery里面的setInterval方法,setInte

百度地图获取数据库点的坐标,并定时刷新到页面上

后台代码 先创建marker点的实体类(并利用Spring注解功能实现自动自动建表) 1 package com.sdtg.ditu.bean; 2 3 import javax.persistence.Column; 4 import javax.persistence.Entity; 5 import javax.persistence.GeneratedValue; 6 import javax.persistence.Id; 7 import javax.persistence.Tabl

ZP的EXTJS学习笔记(三)——邮箱功能的开发(按钮事件、下拉框、分页、record小图标、整条数据格式处理、定时刷新、record复选删除、分组)

照例,先贴效果图: 本人比较满意,短时间开发的邮箱功能,这是收件箱,还有配套的发件箱与删除箱. 简单说下思路: 1.配置model.store,用的是MVC模式,可参考第一篇学习笔记. 2.页面简单布局: Ext.define('KitchenSink.view.mail.InBox', { extend: 'Ext.grid.Panel', alias : 'widget.inbox', xtype: 'inbox', autoHeight:true, bodyStyle:'width:100

Ajax回退刷新页面问题的解决办法

在脚本之家看到一篇文章,觉得以后可能会用上,但是竟然不能收藏,所以只能将其转到博客园. 以下是原文地址: http://www.jb51.net/article/87856.htm 这篇文章主要介绍了Ajax回退刷新页面问题的解决办法的相关资料,非常不错,具有参考借鉴价值,感兴趣的朋友一起学习吧 Ajax 简介: AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. AJAX = 异

动态代理实现多数据库的定时刷新链接信息的应用

开始研究动态代理之前 先简要谈下动态代理的概念 在不改变原有类结构的前提下增强类的功能以及对类原有方法操作,注意是方法不是属性(属性一般被设计为private修饰,不可以直接被调用) 动态代理的基本实例不做阐述,网上一大把 不理解的同学可以直接去搜索. 今天说的是自己在项目中遇到的一个实际的动态代理应用-->定时刷新多数据库的连接接属性 项目背景:项目中存在三个数据库 redis  PostgreSQL(PT库) oracle 我们做的需求是将oracle和redis的数据库链接存储在 PT库中

移动端图片上传解决方案localResizeIMG先压缩后ajax无刷新上传

现在科技太发达,移动设备像素越来越高,随便一张照片2M+,但是要做移动端图片上传和pc上略有不同,移动端你不能去限制图片大小,让用户先处理图片再上传,这样不现实.所以理解的解决方案就是在上传先进行图片压缩,然后再把压缩后的图片上传到服务器. 一翻google之后,发现了localResizeIMG,它会对图片进行压缩成你指定宽度及质量度并转换成base64图片格式,那么我们就可以把这个base64通过ajax传到后台,再进行保存,先压缩后上传的目的就达到了. 处理过程 LocalResizeIM

&lt;微信应用开发系列&gt;定时刷新AccessToken

微信内嵌H5站一直很火,很多公司也想借助微信的用户群和社交群来做点事情,所以对于各位代码君来说也算是一个研究方向吧. access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token.开发者需要进行妥善保存.access_token的存储至少要保留512个字符空间.access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效. 公众号可以使用AppID和AppSecret调用本接口来获取access_token

ajax无刷新表单提交

ajax无刷新提交笔记 数据库自己模拟建一个 执行一下添加功能 php部分采用pdo方法: <?php $db ='mysql'; $host ='localhost'; $port ='3306'; $dbname = 'ajax'; $user = 'root'; $pwd  = ''; $dsn = "$db:host=$host;port=$port;dbname=$dbname";    //设定字符集  $options = array(PDO::MYSQL_ATTR

Ajax无刷新提交

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-