jQuery Show按钮上的加载图像单击并在作业完成后显示按钮

时间:2016-10-26 07:21:49

标签: javascript jquery html cgi

我正在使用一个按钮提交两个表单(后端运行少量脚本并在前端显示输出)“。

HTML -

 <form id="form2" class="form-wrapper"  name="myForm"  action="http://10.1.6.65/cgi-bin/testresult2.py"  method="get" >
     <div class="container">
     <label><b> Client Name</b></label>
     <input id="clientName_details" placeholder="Enter client name" type="text" name="De_Client_name" required >
     <label><b> Version</b></label>
     <input id="Version_details" placeholder="Enter version" type="text" name="De_version" >
     <label><b> DB Name</b></label>
     <input id="dbName_details" placeholder="Enter DB name" type="text" name="De_dbname"  >
     <label><b> HOST Name</b></label>
     <input id="hostName_details" placeholder="Enter HOST name" type="text" name="De_Host">
     <label><b> Email</b></label>
     <input type="email" class="input-field" placeholder="Enter Email" name="email" value="" required/>
     </div>
     </form>
     <dev class=bottom>
   <form id>
        <dev class=tag><b>Do you want to proceed with Upgrade : </b> </dev>
   <input type="button" id="subbut" value="YES">
   <div id="divMsg"  style="display:none;">
    <img src="http://www.javascriptsource.com/img/ajax-loader.gif" alt="Please wait.." />
</div>
   <div id="msg"></div>
   </form>

JS -

 $(document).ready(function() {
        $("#subbut").click(function() {
          $(this).parent().append('<img src="" />');
            $.post($("#form1").attr("action"), $("#form1").serialize(),
              function(data) {
                $("#msg").append(data);
                $.post($("#form2").attr("action"), $("#form2").serialize(),
                  function(data) {
                    $("#msg").append(data);
                      $(this).hide();
                  });
              });
          });
      });

但只有问题是加载是无限时间。但是我们如何限制,以便一旦执行完成后的代码完成,加载图像应该消失。

1 个答案:

答案 0 :(得分:0)

为什么不简单显示/隐藏divMsg

这是代码

$(document).ready(function() {
    $("#subbut").click(function() {
        $("#divMsg").show();
        $.post($("#form1").attr("action"), $("#form1").serialize(),
          function(data) {
            $("#msg").append(data);
            $.post($("#form2").attr("action"), $("#form2").serialize(),
              function(data) {
                $("#msg").append(data);
                  $("#divMsg").hide();
              });
          });
      });
  });