Hướng dẫn dùng setinter JavaScript

  • Định nghĩa
  • Cú pháp
  • Ví dụ
  • Kết luận

Định nghĩa

Phương thức setInterval() gọi một hàm hoặc đánh giá một biểu thức sau một khoảng thời gian xác định (tính bằng mili giây). Tuy nhiên, số lần gọi hàm là liên tục, nó sẽ thực hiện lặp đi lặp lại cho đến khi phương thức clearInterval() được gọi hoặc cửa sổ bị đóng (tải lại trang).

Đơn vị: 1000 ms = 1 giây

Mẹo: Để gọi hàm 1 lần duy nhất sau một số mili giây được chỉ định, hãy sử dụng phương thức setTimeout().

Cú pháp

setInterval(function, milliseconds, param1, param2, ...)

Code language: JavaScript (javascript)

Trong đó:

Tham số Mô tả
function Bắt buộc. Cần có hàm để thực thi
milliseconds Bắt buộc. Khoảng thời gian (tính bằng mili giây) về tần suất thực thi mã. Nếu giá trị nhỏ hơn 10, giá trị 10 được sử dụng
param1, param2, … Không bắt buộc. Các tham số cần truyền vào hàm

Hướng dẫn dùng setinter JavaScript

Ví dụ

Ví dụ 1: Hiển thị thông báo “Hello!” sau mỗi 3 giây (Tải lại trang để kết thúc)

var myVar; function myFunction() { myVar = setInterval(alertFunc, 3000); } function alertFunc() { alert("Hello!"); }

Code language: JavaScript (javascript)

Ví dụ 2: Hiển thị thời gian hiện tại giống như đồng hồ kỹ thuật số

var myVar = setInterval(myTimer, 1000); function myTimer() { var d = new Date(); var t = d.toLocaleTimeString(); document.getElementById("demo").innerHTML = t; }

Code language: JavaScript (javascript)

Ví dụ 3: Chuyển đổi giữa hai màu nền cứ sau 300 mili giây một lần

var myVar = setInterval(setColor, 300); function setColor() { var x = document.body; x.style.backgroundColor = x.style.backgroundColor == "yellow" ? "pink" : "yellow"; } function stopColor() { clearInterval(myVar); }

Code language: JavaScript (javascript)

Kết luận

Như vậy, phương thức setInterval() sẽ thực thi hàm lặp đi lặp lại cho đến khi phương thức clearInterval() được gọi hoặc cửa sổ bị đóng (tải lại trang). Để tìm hiểu rõ hơn về phương thức clearInterval(), mời bạn truy cập clearInterval() trong JavaScript.

Xem thêm:

  • clearInterval() trong JavaScript
  • setTimeout() trong JavaScript
  • clearTimeout() trong JavaScript

Các bạn có thể tham khảo các bài viết hay về JavaScript tại đây.


Hãy tham gia nhóm Học lập trình để thảo luận thêm về các vấn đề cùng quan tâm.

Trong bài này chúng ta tìm hiểu hai hàm setTimeout()setInterval() trong Javascript, đây là hai hàm dùng để hẹn giờ trong JS.

Hướng dẫn dùng setinter JavaScript

Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Hai hàm này có chung một đặc điểm là thiết lập và thực hiện một nhiệm vụ nào đó trong một khoảng thời gian nào đó, số lần thực hiện có thể được lặp đi lặp lại hoặc không. Tuy vậy giữa hai hàm cũng có sự khác nhau về số lần lặp và chi tiết thế nào thì các bạn xem các phần dưới đây.

1. Hàm setTimeout() trong Javascript

Hàm setTimeout() dùng để thiết lập một khoảng thời gian nào đó sẽ thực hiện một nhiệm vụ nào đó và nó chỉ thực hiện đúng một lần.

Cú pháp: setTimeout(function, time)

Bài viết này được đăng tại [free tuts .net]

Trong đó:

  • function: là nội dung cần thực hiện, đây là một hàm
  • time: là khoảng thời gian bao nhiêu (tính bằng mili giây) thì function đó sẽ thực hiện

Ví dụ: Sau 3 giây thì xuất hiện câu chào lên màn hình

XEM DEMO

setTimeout(function(){
    alert("Chào mừng bạn đến với freetuts.net");
}, 3000);

Trong ví dụ này mình đã truyền tham số thứ nhất là một function và tham số thứ hai là số giây mà function sẽ được thực hiện. Ngoài ra bạn có thể viết lại như sau cho dễ nhìn:

XEM DEMO

var do_alert = function(){
    alert("Chào mừng bạn đến với freetuts.net");
};
setTimeout(do_alert, 3000);

Hàm clearTimeout() trong Javascript

Giả sử bạn xây dựng chức năng sau 3 giây thì sẽ xuất hiện thông báo, tuy nhiên sau 2 giây chương trình muốn hủy bỏ thì phải làm thế nào? Lúc này bạn phải sử dụng hàm clearTimeout().

Tham số truyền vào hàm clearTimeout() là đối tượng setTimeout() nên lúc này ban phải đặt hàm setTimeout() vào một biến cụ thể.

// hành động
var action = setTimeout(function(){
    // something
}, 3000);

// hủy hành động
clearTimeout(action);

Ví dụ: XEM DEMO

<script language="javascript">
    var do_alert = setTimeout(function(){
        alert("Chào mừng bạn đến với freetuts.net");
    }, 3000);

    function clearAlert()
    {
        clearTimeout(do_alert);
    }
</script>

<input type="button" onclick="clearAlert()" value="Clear" />

2. Hàm setInterval() trong Javascript

Hàm setInterval() có cú pháp và chức năng giống như hàm setTimeout(), tuy nhiên với hàm setInterval() thì số lần thực hiện lã mãi mãi.

Ví dụ: Cứ sau 3 giây thì xuất hiện câu chào một lần

XEM DEMO

setInterval(function(){
    alert("Chào mừng bạn đến với freetuts.net");
}, 3000);

Trong ví dụ này cứ sau ba giây thì sẽ xuất hiện câu chào và số lần thực hiện sẽ là vĩnh viễn, không tin bạn cứ chạy trang web lên và để vậy.

hàm clearInterval() trong Javascript

Tương tự như hàm clearTimeout(), hàm clearInterval() sẽ xóa đi nhiệm vụ mà ta đã thiết lập trong hàm setInterval(), và ta cũng phải đặt setInterval() trong một biến thì mới clear được.

Ví dụ: Sử dụng hàm setInterval() để xuất câu chào lên màn hình và số lần xuất hiện chỉ 1 lần duy nhất

XEM DEMO

var interval_obj = setInterval(function(){
    alert("Chào mừng bạn đến với freetuts.net");
    clearInterval(interval_obj);
}, 3000);

Trong ví dụ này nội dung thực hiện là xuất hiện câu chào và ngay lập tức xóa nhiệm vụ của interval luôn nên nó chỉ thực hiện 1 lần.

3. Lời kết

Như vậy sự khác nhau giữa hàm setTimeout()setInterval() là đối với hàm setTimeout() thì số lần thực hiện là 1 lần và đối với setInterval() thì số lần thực hiện sẽ là mãi mãi cho tới khi bạn sử dụng hàm clearInterval() để can thiệp vào. Việc sử dụng hàm nào thì phụ thuộc vào nhu cầu của bạn và hãy lưu ý điểm khác nhau này để làm cho đúng.

Bài này mình sẽ dừng ở đây, hy vọng qua các ví dụ bạn sẽ hiểu được cách sử dụng hàm setTimeout()setInterval() trong Javascript, chúc bạn học tốt.