Cách sử dụng vòng lặp for trong JavaScript
1) Vòng lặp là gì? - Trong JavaScript, vòng lặp là một loại cú pháp giúp ta lặp lại việc thực thi một đoạn mã nhiều lần. - Ví dụ, nếu tôi muốn hiển thị lên màn hình 1000 dòng chữ "Lập Trình Web" thì đáng ra phải gõ 1000 câu lệnh document.write("<p>Lập Trình Web</p>") . Tuy nhiên, ...
1) Vòng lặp là gì?
- Trong JavaScript, vòng lặp là một loại cú pháp giúp ta lặp lại việc thực thi một đoạn mã nhiều lần.
- Ví dụ, nếu tôi muốn hiển thị lên màn hình 1000 dòng chữ "Lập Trình Web" thì đáng ra phải gõ 1000 câu lệnh document.write("<p>Lập Trình Web</p>"). Tuy nhiên, với việc sử dụng vòng lặp thì chỉ cần đến ba câu lệnh như bên dưới là đủ.
- Qua ví dụ trên, ta thấy "vòng lặp" giúp ta tiết kiệm được rất nhiều thời gian trong việc viết những đoạn mã cần thực thi nhiều lần liên tiếp.
- Trong JavaScript, vòng lặp được chia làm bốn loại:
- (1) Vòng lặp for
- (2) Vòng lặp for in
- (3) Vòng lặp while
- (4) Vòng lặp do while
- Ở bài hướng dẫn này, bạn sẽ được tìm hiểu về hai loại vòng lặp là for và for in
2) Cách sử dụng vòng lặp for trong JavaScript
- Vòng lặp for dùng để lặp lại việc thực thi một đoạn mã nào đó một số lần.
2.1) Cú pháp
- Trong đó:
- Biểu thức 1 thường là một câu lệnh khai báo biến
- Biểu thức 2 là một biểu thức điều kiện
- Biểu thức 3 thường là một biểu thức làm thay đổi giá trị của biến được khai báo trong biểu thức 1
- Dưới đây là sơ đồ minh họa cho nguyên lý hoạt động của vòng lặp for:
(Biểu thức 1)
(Biểu thức 2)
(Biểu thức 3)
2.2) Ví dụ thứ nhất
- Sử dụng vòng lặp for để hiển thị ba câu "Lập Trình Web" lên màn hình.
- Dưới đây là phần mô tả các bước thực thi của vòng lặp trên:
- Lần thứ nhất
- Khai báo biến i với giá trị là 1.
- Kiểm tra xem điều kiện i 1 có đúng hay không.
2.5) Một số điều cần lưu ý
LƯU Ý THỨ NHẤT
- Trong biểu thức 1 của ví dụ thứ nhất, biến i được khai báo với giá trị là 1 nhưng còn ở ví dụ thứ hai thì biến i được khai báo với giá trị là 0.
- Trong biểu thức 2 của ví dụ thứ nhất, biểu thức điều kiện ta dùng phép so sánh <= nhưng còn ở ví dụ thứ hai thì ta dùng phép so sánh <
- Trong biểu thức 3 của ví dụ thứ nhất và thứ hai thì ta tăng giá trị của biến thêm một, còn ở ví dụ thứ ba thì ta giảm giá trị của biến đi một.
==> Bạn đừng gò bó vào khuôn khổ việc biến được khai báo là mấy, biểu thức điều kiện là gì, ....
==> Cái mà bạn cần quan tâm chính là thiết kế ra một mô hình giúp cho vòng lặp có thể hoạt động đúng theo số lần mong muốn.
- Ví dụ, năm đoạn mã bên dưới có cách viết khác nhau, tuy nhiên chúng có cùng một chức năng là hiển thị bảy câu "Lập Trình Web" lên màn hình
LƯU Ý THỨ HAI
- Biểu thức 1 thường là câu lệnh khai báo biến để tham gia vào biểu thức điều kiện.
- Tuy nhiên, nếu biến dùng để tham gia vào biểu thức điều kiện đã được khai báo và gán giá trị trước đó rồi thì biểu thức 1 ta có thể bỏ trống.
- Ví dụ:
- Còn nếu biến dùng để tham gia vào biểu thức điều kiện đã được khai báo trước đó nhưng chưa được gán giá trị thì trong biểu thức 1 ta chỉ cần gán giá trị cho biến (không cần dùng đến từ khóa var)
- Ví dụ:
LƯU Ý THỨ BA
- Biểu thức 3 trong vòng lặp for rất quan trọng, nó khiến điều kiện của vòng lặp dần dần trở thành bị SAI để giúp cho vòng lặp được kết thúc (Nếu một vòng lặp mà điều kiện luôn luôn đúng thì vòng lặp đó sẽ không bao giờ kết thúc và dẫn đến trường hợp chương trình bị lỗi)
- Tuy nhiên, nếu trong đoạn mã được thực thi có chứa câu lệnh làm thay đổi giá trị của biến điều kiện thì biểu thức 3 ta có thể bỏ trống.
- Ví dụ:
LƯU Ý THỨ TƯ
- Trong phần LƯU Ý THỨ HAI & LƯU Ý THỨ BA tôi đã giới thiệu về trường hợp mà biểu thức 1 và biểu thức 3 có thể bỏ trống, tuy nhiên đó là một số trường hợp đặc biệt. Về mặt viết mã lệnh tốt thì bạn không nên bỏ trống biểu thức như thế, bạn cần phải xây dựng đoạn mã như thế nào để cho cả ba biểu thức đều phải có mặt đầy đủ.
2.6) Vòng lặp for lồng nhau
- Thực chất vòng lặp for lồng nhau chỉ là cách sử dụng nâng cao của vòng lặp for thông thường để giúp cho số lần lặp được tăng theo cấp số nhân.
- Vòng lặp con được đặt vào bên trong vòng lặp cha. Khi điều kiện của vòng lặp cha đúng thì vòng lặp con sẽ được thực thi.
- Dưới đây là cú pháp cơ bản của một vòng lặp for lồng nhau:
- Lưu ý: Bên trong vòng lặp cha, ngoài vòng lặp con thì nó còn có thể chứa thêm các mã lệnh khác.
- Hiển thị dãy số từ 1 đến 50 (bằng cách sử dụng vòng lặp for lồng nhau)
<script> var number = 1; for(i = 0; i < 10; i++){ for(j = 0; j < 5; j++){ document.write(number + " "); number++; } } </script>
- Hiển thị ba dòng dãy số 1 2 3 4 5 6 7 8 9
<script> for(i = 1; i < 4; i++){ var text = ""; for(j = 1; j < 10; j++){ text = text + j + " "; } document.write(text + "<br>"); } </script>
- Hiển thị một ma trận ô vuông giống hình bên dưới:
<style> .square{ height:20px; awidth:20px; float:left; border:1px solid gray; margin-left:5px; margin-bottom:5px; } </style> <script> for(var i = 0; i < 5; i++){ for(var j = 0; j < 10; j++){ document.write("<div class='square'></div>"); } document.write("<div style='clear:both'></div>"); } </script>
2.7) Lệnh break
- Lệnh break thường được đặt vào bên trong vòng lặp for.
- Khi lệnh break được thực thi, vòng lặp sẽ kết thúc mặc cho điều kiện của vòng lặp có còn đúng hay không.
- Lặp lại 10 lần việc hiển thị giá trị của biến number.
- Sau mỗi lần hiển thị cho giá trị của biến number tăng thêm một.
- Tuy nhiên, đến khi giá trị của biến number được tăng lên thành 5 thì kết thúc vòng lặp.
<script> var number = 1; for(var i = 1; i <= 10;i++){ document.write(number + "<hr>"); number++; if(number==5){ break; } } </script>
2.8) Lệnh continue
- Lệnh continue thường được đặt vào bên trong vòng lặp for.
- Khi lệnh continue được thực thi, những câu lệnh còn lại của lần lặp hiện tại sẽ bị bỏ qua.
- Hiển thị dãy số từ một đến mười (ngoại trừ các số 2, 5, 9)
<script> for(var i = 1; i <= 10;i++){ if(i==2 || i==5 || i==9){ continue; } document.write(i + "<br>"); } </script>
2.9) Lặp qua một lần các phần tử của mảng
- Ta có thể sử dụng vòng lặp for để lặp qua một lần các phần tử trong mảng.
<script> var mobile = ["HTC","Nokia","SamSung","LG","Apple","Lenovo"]; for(var i = 0; i < mobile.length; i++){ document.write(mobile[i] + "<br>"); } </script>
3) Cách sử dụng vòng lặp for in trong JavaScript
- Vòng lặp for in dùng để lặp qua một lần các thuộc tính của một đối tượng.
<script> var SinhVien = { name:"Nguyễn Thành Nhân", year:1993, gender:"Nam", hometown:"Cần Thơ" } for(x in SinhVien){ document.write(SinhVien[x]); document.write("<hr>"); } </script>