Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Mengekstrak Pelbagai Elemen Rawak daripada Array dalam JavaScript Tanpa Pendua?

Bagaimana untuk Mengekstrak Pelbagai Elemen Rawak daripada Array dalam JavaScript Tanpa Pendua?

Patricia Arquette
Lepaskan: 2024-10-29 11:13:29
asal
890 orang telah melayarinya

How to Extract Multiple Random Elements from an Array in JavaScript Without Duplicates?

Cara Mengekstrak Berbilang Elemen Rawak daripada Array dalam JavaScript

Masalah:

Mendapatkan semula elemen rawak tunggal daripada tatasusunan adalah mudah menggunakan formula Math.floor(Math.random() * array.length). Walau bagaimanapun, mengambil beberapa elemen rawak tanpa pendua boleh mencabar.

Penyelesaian:

Untuk mendapatkan bilangan unsur rawak yang ditentukan daripada tatasusunan, ikuti langkah berikut:

  1. Kocok tatasusunan menggunakan tatasusunan.sort(() => 0.5 - Math.random()). Baris ini memastikan elemen dalam tatasusunan adalah rawak.
  2. Ekstrak n elemen pertama daripada tatasusunan yang dikocok menggunakan selected = shuffled.slice(0, n). Baris ini memilih n elemen pertama daripada tatasusunan yang dikocok.

Contoh:

Pertimbangkan kod berikut:

<code class="javascript">n = 5;
array = Array.from({ length: 50 }, (v, k) => k * 10); // [0,10,20,30,...,490]
var shuffled = array.sort(function () { return 0.5 - Math.random() });
var selected = shuffled.slice(0, n);

document.querySelector('#out').textContent = selected.toString();</code>
Salin selepas log masuk

Ini kod mengocok tatasusunan 50 nombor dan mendapatkan semula 5 elemen rawak pertama, memaparkannya dalam dokumen HTML.

Atas ialah kandungan terperinci Bagaimana untuk Mengekstrak Pelbagai Elemen Rawak daripada Array dalam JavaScript Tanpa Pendua?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan