做爲前端開發人員,JS和JQuery是咱們常常用到的開發語言和工具類庫。咱們都曉得,在jQuery中有一個很強大的方法——stop(),他是阻止在連續動畫或事件中出現重複累積情況的方法。那麼,stop()怎麼用呢?小碼哥來帶你們先認識一下stop()吧:javascript
stop()在語法上有兩個參數,分別都是Boolean布爾值。且都是可選的,可是也有規定,以下:
前端
$(selector).stop(stopAll,goToEnd)java
參數:(默認狀況下,不寫參數,則會被認爲兩個參數都是false。)ide
stopAll:可選。規定是否中止被選元素的全部加入隊列的動畫。意思就是若是該參數值爲true,則會中止全部後續動畫或事件。若是該參數值爲false,則只中止被選元素當前執行的動畫,後續動畫不受影響。所以,該參數通常都爲false。工具
goToEnd:可選。規定是否容許完成當前動畫,該參數只能在設置了stopAll參數時使用。上面咱們說了,stopAll參數咱們通常都會寫fasle值,不是默認,而是真實的寫上該參數。那麼goToEnd參數就有兩個選擇了,一個是false,一個是true。其中意思,你們應該都明白了。通常都爲true。意思就是容許完成當前動畫。動畫
下面是對應的代碼:url
HTML:
spa
<div id="content">隊列
<div class="slide_box">事件
<div class="img">
<img src="p_w_picpaths/page_a.png">
<div class="start"> <a class="start_btn" href="javascript:void(0)">開始抽獎</a> </div>
</div >
<div class="img" style="display:none;" >
<img src="p_w_picpaths/page_b.png">
<a class="rank_30" href="javascript:void(0);">30級</a>
<a class="rank_45" href="javascript:void(0);">45級</a>
<a class="rank_55" href="javascript:void(0);">55級</a>
</div>
<div class="img" style="display:none;" >
<img src="p_w_picpaths/page_c.png">
<a class="prize_notes" href="javascript:void(0);">獎品記錄</a>
</div>
</div>
</div>
CSS:
#content{/* margin-top:10em;*/ width:48em; margin:0 auto;}
#content div{ display:block; width:100%;}
#content div.cont_b{ position:relative; text-align:center;background:url(../p_w_picpaths/content_bgb.jpg) no-repeat; background-size:100% 100%;}
#content div img{ display:block; width:100%; border:none;}
#content div .slide_box{ position:absolute; top:0px; width:100%; }
#content div .img .start{ position:absolute; top:290px;}
#content div .img a.start_btn{ display:block; width:150px; height:150px; text-indent:-9999px; margin:0 auto;}/*修改*/
#content div .img a.rank_30{ position:absolute; top:230px; left:70px; display:block; width:250px; height:60px; text-indent:-9999px;}
#content div .img a.rank_45{ position:absolute; top:230px; left:460px; display:block; width:250px; height:60px; text-indent:-9999px;}
#content div .img a.rank_55{ position:absolute; top:430px; left:170px; display:block; width:280px; height:60px; text-indent:-9999px;}
#content div .img a.prize_notes{ position:absolute; top:470px; right:50px; display:block; width:150px; height:150px; text-indent:-9999px;}
JS_jQuery:
var page =$(".slide_box .img");
var page_num = page.length;
var num = 0;
$(".next_btn").click(function(e){
if(num < 2){
page.slideUp().stop(false,true).eq(num+1).slideDown();
num++;
}else{
page.slideUp().stop(false,true).eq(0).slideDown();
num = 0;
}
});
});
上面是小碼哥在工做中寫一個點擊事件效果時遇到的事件累積狀況,,在JS部分,有用到stop()方法,你們能夠將參數去掉或改變,試試看。但願對你們有所幫助。嘎嘎