หยุด setInterval


120

ฉันต้องการหยุดช่วงเวลานี้ในerrorตัวจัดการไม่ให้ทำงานซ้ำ ๆ เป็นไปได้หรือไม่และถ้าเป็นเช่นนั้นได้อย่างไร

// example code
$(document).on('ready',function(){
    setInterval(updateDiv,3000);
});

function updateDiv(){
    $.ajax({
        url: 'getContent.php',
        success: function(data){
            $('.square').html(data);
        },
        error: function(){
            $.playSound('oneday.wav');
            $('.square').html('<span style="color:red">Connection problems</span>');
            // I want to stop it here
        }
    });
}

2
อาจซ้ำกันของStop setInterval call ใน JavaScript
Mohammad

คำตอบ:


243

คุณต้องกำหนดค่าส่งคืนของsetIntervalเป็นตัวแปรภายในขอบเขตของตัวจัดการการคลิกจากนั้นใช้clearInterval()ดังนี้:

var interval = null;
$(document).on('ready',function(){
    interval = setInterval(updateDiv,3000);
});

function updateDiv(){
    $.ajax({
        url: 'getContent.php',
        success: function(data){
            $('.square').html(data);
        },
        error: function(){
            clearInterval(interval); // stop the interval
            $.playSound('oneday.wav');
            $('.square').html('<span style="color:red">Connection problems</span>');
        }
    });
}

4
ลิงก์ไปยังเอกสาร: clearInterval ()และsetInterval ()
Bruno Peres

คุณยังสามารถsetTimout()ใช้ได้เพียงครั้งเดียวเท่านั้น
Justin Liu

21

ใช้ตัวแปรและเรียกclearIntervalเพื่อหยุดมัน

var interval;

$(document).on('ready',function()
  interval = setInterval(updateDiv,3000);
  });

  function updateDiv(){
    $.ajax({
      url: 'getContent.php',
      success: function(data){
        $('.square').html(data);
      },
      error: function(){
        $.playSound('oneday.wav');
        $('.square').html('<span style="color:red">Connection problems</span>');
        // I want to stop it here
        clearInterval(interval);
      }
    });
  }

11

คุณต้องกำหนดค่าที่ส่งคืนของsetIntervalฟังก์ชันให้กับตัวแปร

var interval;
$(document).on('ready',function(){
    interval = setInterval(updateDiv,3000);
});

แล้วใช้clearInterval(interval)เพื่อล้างอีกครั้ง


8

ใช้สิ่งนี้ฉันหวังว่าจะช่วยคุณได้

var interval;

function updateDiv(){
    $.ajax({
        url: 'getContent.php',
        success: function(data){
            $('.square').html(data);
        },
        error: function(){
            /* clearInterval(interval); */
            stopinterval(); // stop the interval
            $.playSound('oneday.wav');
            $('.square').html('<span style="color:red">Connection problems</span>');
        }
    });
}

function playinterval(){
  updateDiv(); 
  interval = setInterval(function(){updateDiv();},3000); 
  return false;
}

function stopinterval(){
  clearInterval(interval); 
  return false;
}

$(document)
.on('ready',playinterval)
.on({click:playinterval},"#playinterval")
.on({click:stopinterval},"#stopinterval");

4

เราสามารถหยุดช่วงเวลาที่กำหนดได้อย่างง่ายดายโดยการเรียกช่วงเวลาที่ชัดเจน

var count = 0 , i = 5;
var vary = function intervalFunc() {
  count++;
      console.log(count);
    console.log('hello boy');  
    if (count == 10) {
      clearInterval(this);
    }
}

  setInterval(vary, 1500);

ปฏิบัติแย่มาก. ประการแรกอาจหมายความว่าพวกsetIntervalเขาอาจรั่วไหลอย่างไม่แน่นอน - ไม่มีตัวแปรที่เกี่ยวข้องเพื่อควบคุมมัน ที่ 2 คุณไม่ชัดเจนthisเนื่องจากthisไม่ใช่ช่วงเวลา หากคุณใช้TypeScriptคุณจะมีปัญหา:No overload matches this call.Overload 1 of 2, '(intervalId: Timeout): void', gave the following error: Argument of type 'this' is not assignable to parameter of type 'Timeout'.
Pedro Ferreira

-2

var flasher_icon = function (obj) {
    var classToToggle = obj.classToToggle;
    var elem = obj.targetElem;
    var oneTime = obj.speed;
    var halfFlash = oneTime / 2;
    var totalTime = obj.flashingTimes * oneTime;

    var interval = setInterval(function(){
        elem.addClass(classToToggle);
        setTimeout(function() {
            elem.removeClass(classToToggle);
        }, halfFlash);
    }, oneTime);

    setTimeout(function() {
        clearInterval(interval);
    }, totalTime);
};

flasher_icon({
    targetElem: $('#icon-step-1-v1'),
    flashingTimes: 3,
    classToToggle: 'flasher_icon',
    speed: 500
});
.steps-icon{
    background: #d8d8d8;
    color: #000;
    font-size: 55px;
    padding: 15px;
    border-radius: 50%;
    margin: 5px;
    cursor: pointer;
}
.flasher_icon{
  color: #fff;
  background: #820000 !important;
  padding-bottom: 15px !important;
  padding-top: 15px !important;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet"> 

<i class="steps-icon material-icons active" id="icon-step-1-v1" title="" data-toggle="tooltip" data-placement="bottom" data-original-title="Origin Airport">alarm</i>


4
โปรดอธิบายว่ารหัสนี้ทำหน้าที่อะไรและเกี่ยวข้องกับคำถามอย่างไร
JJJ
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.