2016-09-06 99 views
1

我有3個DIV如下jQuery的顯示和隱藏DIV

<div id="div1"></div> 
<div id="spinnerDiv" style="display:none"></div> 
<div id="div2" style="display:none"></div> 

上的按鈕,點擊我要顯示在div下列方式

第1步:隱藏D​​IV1
步驟2:幾毫秒顯示spinnerdiv說3000
第3步:隱藏spinnerdiv並顯示DIV2

我曾嘗試follwoing方法,但它不能正常工作:

button click function(){ 
    $("#div1").hide(); 
    $("#spinnerDiv").show().delay(3000).queue(function() { 
     $(this).hide(); 
     $("#div2").show(); 
    }); 
} 
+0

你的代碼工作正常,檢查我的答案與片段 –

+0

您是right.Just聽錯了,因爲從我身邊的一些錯誤。任何方式接受使用除上述以外的其他方法的答案 – ksg

回答

2

setTimeout試試:

$("#div1").hide(); 
$("#spinnerDiv").show(); 
setTimeout(function() { 
    $("#spinnerDiv").hide(); 
    $("#div2").show(); 
}, 3000); 
1

嘗試使用一個回調,而不是隱藏()的函數的第一部分,因爲我是一個沒有延遲的粉絲我會用的setTimeout:

$("button").click(function(){ 
    $("#div1").fadeOut(1, function() { 
     var s = $("#spinnerDiv"); 
     s.show(); 
     setTimeout(function() { 
      s.hide(); 
      $("#div2").show(); 
     }, 3000); 
    }); 
} 
1

您是否嘗試過使用setTimeout呢?

button click function(){ 
    $("#div1").hide(); 
    $("#spinnerDiv").show(); 

    setTimeout(function() { 
     $('#spinnerDiv').hide(); 
     $("#div2").show(); 
    }, 3000); 

} 
0

你在這裏

function thisAction(){ 
 
    $("#div1").hide(); 
 
    $("#spinnerDiv").hide(); 
 
     $("#div2").hide(); 
 
     
 
    $("#spinnerDiv").show().delay(3000).queue(function() { 
 
       $(this).hide(); 
 
       $("#div2").show(); 
 
      }); 
 

 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<div id="div1">div 1</div> 
 
<div id="spinnerDiv" style="display:none"> spinnerDiv</div> 
 
<div id="div2" style="display:none">div2</div> 
 

 
<button onclick='thisAction()' >

+0

請在動畫效果之後再次點擊按鈕。 – ksg

+0

剛剛更新了divs的初始狀態 –