Rumah >hujung hadapan web >tutorial js >Gelung: Untuk Gelung, Sementara Gelung, Untuk...Daripada Gelung, Untuk...Dalam Gelung

Gelung: Untuk Gelung, Sementara Gelung, Untuk...Daripada Gelung, Untuk...Dalam Gelung

PHPz
PHPzasal
2024-08-07 09:57:321193semak imbas

Loops: For Loops, While Loops, For...Of Loops, For...In Loops

Maksud gelung adalah untuk mengulangi beberapa fungsi.

Beberapa jenis gelung termasuk:

  • untuk gelung
  • gelung sambil
  • untuk...gelung
  • untuk...dalam gelung

Untuk Gelung

Untuk boleh menulis gelung untuk mudah seperti berikut:

for (let i = 1; i <= 10; i++) {
  console.log(i); // prints numbers 1-10
}

Untuk menggelungkan tatasusunan, kita boleh lakukan seperti berikut:

const animals = ['lizard', 'fish', 'turtle'];

for (let i = 0; i < animals.length; i++) {
  console.log(i, animals[i]);
}
// 0 'lizard'
// 1 'fish'
// 2 'turtle'

Kita juga boleh menggelungkan tatasusunan ini secara terbalik:

for (let i = animals.length - 1; i >= 0; i--) {
  console.log(i, animals[i]);
}

// 2 'turtle'
// 1 'fish'
// 0 'lizard'

Kami juga boleh membuat gelung dalam gelung:

for (let i = 0; i <= 2; i++) {
  for (let j = 0; j < 2; j++) {
    console.log(`i=${i}, j=${j}`);
  }
}

// i=0, j=0
// i=0, j=1
// i=1, j=0
// i=1, j=1
// i=2, j=0
// i=2, j=1

Ini berguna jika kita ingin mengulangi pelbagai tatasusunan:

const seatingChart = [
  ['Abigale', 'Tim', 'Cynthia'],
  ['Bob', 'Carter', 'Zane', 'Tanja'],
  ['Quin', 'Xavier'],
];

// To print each name individually from seatingChart:
for (let i = 0; i < seatingChart.length; i++) {
  for (let j = 0; j < seatingChart[i].length; j++) {
    console.log(seatingChart[i][j]);
  }
}

Manakala Gelung

Contoh gelung while yang ringkas ialah:

let num = 0;

// to print out 0 through 4:
while (num < 5) {
  console.log(num);
  num++;
}

Kata kunci pecah

Kata kunci rehat boleh digunakan untuk keluar dari gelung sementara:

let input = prompt('Say something:');
while (true) {
  input = prompt(input);
  if (input === 'stop copying me') {
    break; // finally stops prompting user
  }
}

Ia juga boleh digunakan untuk keluar dari gelung for. Katakan kita mempunyai talian:

let line = ['Abby', 'Salvia', 'Jamie', 'Carter', 'John'];

dan kami mahu mengeluarkan semua orang yang datang sebelum Jamie, tetapi bukan Jamie:

for (let i = 0; i < line.length; i++) {
  if (line[i] === 'Jamie') break;
  console.log(line[i]);
}

Untuk...Daripada Gelung

Jika kita ingin mencetak setiap nilai daripada tatasusunan, kita boleh melakukan sesuatu seperti:

let people = ['Agitha', 'Bruce', 'Charlie', 'Dane', 'Ernie'];
// to print each persons name:
for (let person of people) {
  console.log(person);
}

Untuk menjadikan contoh carta tempat duduk kami dari sebelumnya lebih mudah dibaca, kami boleh melakukan:

const seatingChart = [
  ['Abigale', 'Tim', 'Cynthia'],
  ['Bob', 'Carter', 'Zane', 'Tanja'],
  ['Quin', 'Xavier'],
];

// To print each name individually from seatingChart:
for (let row of seatingChart) {
  for (let person of row) {
    console.log(person);
  }
}

Untuk...Dalam Gelung

Jika kita ingin mengulangi setiap pasangan nilai kunci dalam objek, kita boleh melakukan sesuatu seperti:

const testScores = {
  jim: 34,
  abby: 93,
  greg: 84,
  mark: 95,
  melvin: 73,
};

for (let person in testScores) {
  console.log(`${person} scored ${testScores[person]}`);
}

Jika kita ingin mendapatkan purata Skor ujian menggunakan For...Of, kita boleh lakukan seperti berikut:

let total = 0;
let scores = Object.values(testScores);
for (let score of scores) {
  total += score;
}
let avg = total / scores.length;
console.log(avg);

Atas ialah kandungan terperinci Gelung: Untuk Gelung, Sementara Gelung, Untuk...Daripada Gelung, Untuk...Dalam Gelung. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn