Return to Video

Looping through Arrays (Video Version)

  • 0:01 - 0:04
    Ta cùng quay lại với chương trình mảng về bạn bè của tôi.
  • 0:04 - 0:07
    Có một điều khiến tôi cảm thấy rất khó chịu.
  • 0:07 - 0:11
    Mỗi khi thêm một người bạn mới vào mảng, tôi lại phải thêm một lệnh text ở dưới đây.
  • 0:11 - 0:13
    Giả sử tôi thêm Winston.
  • 0:13 - 0:15
    Cậu ta không tự động hiển thị đâu.
  • 0:15 - 0:21
    Nếu tôi muốn cậu ta hiển thị, tôi phải nhập text(myFriends[3], sau đó thay đổi vị trí y và ta sẽ nhìn thấy Winston.
  • 0:24 - 0:25
    Quá nhiều thứ phải làm.
  • 0:26 - 0:31
    Tôi chỉ muốn mỗi lần thêm ai đso vào mảng, lệnh văn bản sẽ tự động được nhập.
  • 0:32 - 0:35
    Các bạn có nhớ những gì đã học về vòng lặp không?
  • 0:35 - 0:38
    Đó là phương pháp lặp mã liên tục rất hiệu quả.
  • 0:38 - 0:43
    Giống như khi ta muốn có một hàng cây hay một chùm bóng.
  • 0:43 - 0:50
    Hóa ra, vòng lặp còn rất hữu ích trong việc chạy một đoạn mã trên từng phần tử trong một mảng.
  • 0:50 - 0:57
    Trên thực tế, hầu như mỗi khi sử dụng mảng, ta đều phải sử dụng vòng lặp. Chúng phối hợp với nhau rất tốt.
  • 0:57 - 1:04
    Ta hãy sử dụng vòng lặp để hiển thị tên bạn bè của tôi, thay vì phải nhập toàn bộ chỗ lệnh văn bản này, để cho các bạn thấy ý đồ của tôi.
  • 1:04 - 1:08
    Ta sẽ bắt đầu với ba câu hỏi mà ta thường tự đặt ra khi tạo vòng lặp.
  • 1:08 - 1:13
    Thứ nhất, tôi muốn lặp cái gì? Hãy nhìn lên đây. Cái gì đang được lặp lại? Lệnh text.
  • 1:13 - 1:26
    Mỗi lần lặp tôi muốn thay đổi cái gì? Ta cùng quan sát và xem có gì khác biệt. Vị trí y và chỉ số hiện tại, đúng không? Vậy là friendNum và vị trí y.
  • 1:26 - 1:34
    Và ta nên lặp trong bao lâu? Ta sẽ lặp cho tới khi không còn bạn bè để lặp nữa.
  • 1:34 - 1:37
    Sau khi đã xác định được những gì mình cần, ta có thể tiến hành tạo vòng lặp.
  • 1:37 - 1:44
    Trước hết ta tạo một biến đếm để theo dõi vị trí của mình trong vòng lặp. Ta nhập var friendNum = 0.
  • 1:44 - 1:50
    Ta sẽ bắt đầu với số 0 vì 0 là phần tử đầu tiên trong mảng, không phải 1.
  • 1:51 - 1:58
    Sau đó ta tạo vòng lặp while. Ta nhập while(friendNum < myfriends.length).
  • 1:58 - 2:04
    Ta sẽ so sánh biến đếm hiện tại với tổng số phần tử trong mảng.
  • 2:04 - 2:08
    Và áp dụng lệnh văn bản trong vòng lặp.
  • 2:08 - 2:13
    Ta nhập text(myFriends[ - và tại vị trí này, thay vì số, ta sẽ nhập friendNum vì friendNum thể hiện số bạn bè hiện tại.
  • 2:13 - 2:18
    Bây giờ ta sẽ chỉ thêm một vị trí thôi.
  • 2:18 - 2:26
    Ta đang mắc phải lỗi vòng lặp vô hạn vì ta chưa thay đổi friendNum.
  • 2:26 - 2:30
    Hãy nhớ rằng, mỗi lần lặp ta đều phải gia tăng friendNum, nếu không vòng lặp sẽ chạy mãi mãi vì điều kiện luôn luôn đúng.
  • 2:35 - 2:39
    Tôi thấy có điều gì đó ở đây. Tôi sẽ chú thích mã cũ để có thể hiểu được chuyện gì vừa xảy ra.
  • 2:39 - 2:44
    Ta đã hiện thị toàn bộ tên rồi, nhưng chúng đang chồng chéo lên nhau.
  • 2:44 - 2:46
    Vì vậy ta cần phải thay đổi vị trí y.
  • 2:46 - 2:50
    Ta nhập friendNum*30.
  • 2:50 - 2:55
    Vậy là tốt rồi nhưng Sophia đang bị ra khỏi màn hình và sẽ không vui tí nào nếu biết đâu.
  • 2:55 - 3:00
    Ta phải thêm 30 vào biến. Giờ thì tên sẽ hiển thị từ 30 trở đi.
  • 3:00 - 3:04
    Đẹp rồi đấy! Hiện tại ta đã có một vòng lặp hiển thị mảng.
  • 3:04 - 3:14
    Điều đó có nghĩa là khi ta thêm người, ví dụ như ông OhNoes kia, hay thậm chí Sal, vào mảng thì Sal sẽ trở thành bạn của tôi. Tuyệt vời!
  • 3:14 - 3:21
    Các bạn có thể thấy tên mới sẽ tự động được hiển thị vì vòng lặp luôn luôn rà lại toàn bộ mảng.
  • 3:21 - 3:24
    Vậy là ta có thể xóa mã được rồi. Nó không cần thiết nữa.
  • 3:24 - 3:28
    Ta cùng xem lại mã này một chút nhé.
  • 3:28 - 3:32
    Ta bắt đầu với friendNum = 0.
  • 3:32 - 3:35
    Ta sẽ kiểm tra xem liệu friendNum có nhỏ hơn độ dài hiện tại không.
  • 3:35 - 3:38
    0 nhỏ hơn 6. Như vậy điều kiện đúng.
  • 3:38 - 3:42
    Sau đó ta nhập vào bên trong, text myFriends friendNum.
  • 3:42 - 3:44
    Lần đầu tiên sẽ là số 0.
  • 3:44 - 3:47
    Sau đó 30 + 0 * 30.
  • 3:47 - 3:54
    Sophia sẽ được hiển thị tại vị trí 10 và 30. Đó chính là chức năng của đoạn mã này.
  • 3:54 - 3:56
    Tiếp theo là friendNum ++. Sau đó tới phần tử 1.
  • 3:56 - 4:00
    Đoạn mã sẽ lại quay lại từ đầu và tự hỏi, “OK, 1 có nhỏ hơn 6 không? Có”.
  • 4:00 - 4:02
    Rồi cứ thế liên tục.
  • 4:02 - 4:11
    Và cuối cùng ta có Sal. Hãy nhớ rằng, Sal là phần tử thứ 6 trong mảng, nhưng chỉ số lại là 5, vì ta bắt đầu từ 0.
  • 4:11 - 4:13
    Vậy 5 có nhỏ hơn 6 không? Có.
  • 4:13 - 4:15
    Ta hiển thị myFriends 5.
  • 4:15 - 4:22
    Sau đó biến tăng lên 6 và ta lại hỏi, “6 có nhỏ hơn 6 không?” Không, nó bằng nhau.
  • 4:22 - 4:25
    Vây điều kiện sai. Máy tính sẽ không hiển thị phần tử thứ 6,
  • 4:25 - 4:29
    cũng tốt vì chẳng có gì ở chỉ số 6 cả.
  • 4:29 - 4:33
    Ta có phần tử thứ 6, nhưng không có chỉ số 6.
  • 4:33 - 4:39
    Chuyện 0 và 1 có thể khá khó hiểu, nhưng dần dần bạn sẽ quen thôi.
  • 4:39 - 4:41
    Được rồi, vậy đó chính là vòng lặp.
  • 4:41 - 4:45
    Bây giờ, nếu muốn, các bạn cũng có thể sử dụng vòng lặp for nếu thích vòng lặp for hơn.
  • 4:45 - 4:52
    Đối với vòng lặp for, ta sẽ nhập for, sau đó var friendNum = 0, kế đến là điều kiện
  • 4:52 - 4:57
    'friendNum < myFriends.length'
  • 4:57 - 5:02
    và gia số friendNum ++,
  • 5:02 - 5:07
    rồi ta có thể đưa dòng mã này vào bên trong vòng lặp for.
  • 5:07 - 5:10
    Tôi sẽ thay đổi x để các bạn thấy
  • 5:10 - 0:00
    quy trình giống y hêt. Sử dụng vòng lặp nào là tùy thuộc vào bạn, tôi chỉ nhấn mạnh nên sử dụng vòng lặp khi làm việc với mảng vì nó cực kỳ hiệu quả.
Title:
Looping through Arrays (Video Version)
Description:

more » « less
Video Language:
English
Duration:
05:22

Vietnamese subtitles

Incomplete

Revisions