javascript - setInterval為什么只執行一次
問題描述
簡單的背景切換
jquery部分
$(function(){function direct(){for(var i=0;i<2;i++){$('.bg_img').eq(i).show().siblings().hide();} } setInterval(direct,1000);})
html部分
<p class='main_bg'><p class='bg_img bg1'></p><p class='bg_img bg2'></p> </p>
css部分
.bg2默認display:none;
setInterval()只執行了一次,就想問為啥進入不了第二次?
各位大佬不要鄙視我,感謝您的解答~
問題解答
回答1:不是鄙視你,但這明顯是語法問題……實際上我認為 setInterval 一直都在執行,但是你的函數 direct 的運行結果是固定的,循環的最終結果是第二張顯示第一張隱藏,所以看起來好像沒執行一樣。
你應該這樣做:
var current = 0;function direct(){ $('.bg_img').eq(current).show() .siblings().hide(); current++; if (current > 1) { current = 0; } }
這里用到了閉包,把狀態保存在定時器的外面,才能夠每次往下循環。
另外再補充一點渲染的知識。對于這種用 for 循環改變視圖狀態,瀏覽器會把這些狀態都緩存起來,然后擇機渲染,而不是你一修改它就立刻渲染。所以你連閃一下都看不到。
回答2:參考一下
$(function(){ function direct(i){ $('.bg_img').eq(i).show().siblings().hide(); } var i = 0; setInterval(function () { direct(i) i = (i + 1) % $('.bg_img').length }, 1000);})回答3:
setInterval(function direct(){
for(var i=0;i<2;i++){ $('.bg_img').eq(i).show().siblings().hide(); }},1000); 直接這樣試試,控制臺看看,有沒有報錯,如果報錯的話,js也不會繼續執行了的。回答4:
循環一次之后i的值為1 然后就一直是1 用let試試
回答5:你是不是要的這種效果,按順序一個一個顯示?
jQuery(function($){ var bgImg = $('.bg_img'),maxIndex = bgImg.length - 1,i = 0; function direct(){bgImg.eq(i).show().siblings().hide();if (i < maxIndex) { i++;} else { i = 0;} } setInterval(direct, 1000);});回答6:
$(function(){
var index = 0;setInterval(function(){ (index < $(’.bg_img’).length) ? index ++ : index = 0; $(’.bg_img’).eq(index).show().siblings().hide();},1000);
})
回答7:setInterval(direct(),1000);
不知道對不對,但是總感覺是這個的問題
相關文章:
1. javascript - 微信h5發送圖文信息,部分設備點擊“發送”按鈕時沒反應,問題較難重現,如何能找到可能存在問題的點?2. objective-c - 做一個百度地圖定位的demo,結果出錯好多。3. 微信小程序session無法緩存的問題4. java-web - Java WEB:什么樣的jar包必須放到WEB-INF下?有些包放外面tomcat就起不來5. javascript - 關于微信授權的問題。6. java - 輸出4個不相等整數之間所有任意三個整數的乘積7. css - 如何使用 vue transition 實現 ios 按鈕一樣的平滑切換效果8. 如何使用Java1.8編譯1.6JVM可運行的class文件9. angular.js - 公眾號H5頁面 angularjs 怎么動態修改title值(微信6.5.5,動態修改不行 6.5.7闊以)10. node.js - 如何在服務器部署vuejs項目?
