Уроки JavaScript – приклади використання випадковості

В JavaScript досить часто потрібно використовувати випадковість або випадкове поводження. Найпростішим прикладом буде отримання випадкового числа для проведення жеребкування. Або, наприклад, уявити можливий результат кидка монети. Але існує багато різних видів випадковості, і для різних додатків потрібно підбирати свій вид випадкового результату.

 

 

Найпростіша випадковість

Найпростішою формою випадковості, яка вбудована в JavaScript, є функція Math.random(). Щоб побачити її в дії, наберіть в консолі браузера (виклик консолі Ctrl+Shift+I) функцію:

Math.random();
//0.2735944957535754 – приклад результату

 

Функція Math.random() завжди повертає число з рухомою комою від 0 до 1.

Примітка: Технічно, число, що повертається Math.random(), може бути 0, але ніколи не буде точно 1.

 

Оскільки ця функція так часто використовується, Math.random() часто поміщається у власну функцію, яку потім викликають в скрипті:

<script>
function getRandom() {
  return Math.random();
}
</script>

 

 

Проблема, звичайно, в тому, що функція завжди створює випадкове число в дуже обмеженому діапазоні; більшість інших прикладів коду в сьогоднішній практичній статті призначені для вирішення цієї проблеми.

 

 

Випадковість між числами: min включено, max виключено

Для цієї функціональності нам буде потрібно трохи математики:

 

З рухомою комою

function getRandomFloat(min, max) {
  return Math.random() * (max - min) + min;
}
getRandomFloat(15, 127);
//61.65118618053822 – приклад результату

 

 

З використанням цілого числа

function getRandomInt(min, max) {
  return Math.floor(Math.random() * (max - min)) + min;
}
getRandomInt(99, 720);
//552 – приклад результату

 

 

 

Випадкове ціле число в діапазоні (включаючи мінімальне та максимальне)

function getRandomInRange(min, max) {
  return Math.floor(Math.random() * (max - min + 1)) + min;
}
getRandomInRange(1, 175);
//73 – приклад результату

 

 

Результат кидка монети (випадкові Правда/Хиба, 1/0)

Якщо ви хочете, щоб результатом був простий випадковий результат, наприклад 0 або 1, що можна представити у вигляді кидка монети, використовуйте наступний рецепт:

function coinToss() {
  return Math.floor(Math.random() * 2);
}
coinToss();
//1 – приклад результату

 

 

Випадковий результат з використанням винятків

Для обмеженого діапазону цілих чисел створіть масив чисел, з яких ви хочете вибирати, і використовуйте наступний рецепт для випадкового вибору з масиву:

<script>
var numPool = [ 2, 3, 5, 8, 11, 25 ],
rand = numPool[Math.floor(Math.random() * numPool.length)];
console.log(rand);
//11 – приклад результату
</script>

 

 

Випадковий, неповторюваний масив

Для невеликого набору чисел створіть масив, заповнений елементами, перемішайте їх випадковим чином, помістіть результати в новий масив, а потім витягніть перемішані елементи по одному:

<script>
var numPool = [ 18, 42, 37, 9, 24, 100 ];
function shuffle(numPool) {
  for(var j, x, i = numPool.length; i; j = parseInt(Math.random() * i), x = numPool[--i], numPool[i] = numPool[j], numPool[j] = x);
  return numPool;
};
var randomResult = shuffle(numPool);
while( randomResult.length > 0 ) {
  console.log( randomResult.pop() );
}
// в результаті вказаний масив буде перемішаний випадковим чином
</script>

 

 

 

Криптографічна випадковість в JavaScript

Жоден з розглянутих методів не створює числа з достатньою випадковістю для використання в криптографічно безпечних функціях. До речі, і результати функції Math.random() не є достатньо випадковими.

Для криптографічної випадковості в JavaScript ми можемо використовувати API веб-криптографії, створивши збірний масив (typedArray):

var cryptoStor = new Uint16Array(5);

 

Тут ми створюємо масив з п’ятьма різними слотами, кожен з яких може містити непідписане (беззнакове) 16-розрядне ціле число. Для інших параметрів цілого числа ви можете використовувати Int8Array, Uint8Array, int16Array, Int32Array і Uint32Array.

 

Після цього ви можете заповнити масив випадковими числами певного типу:

window.crypto.getRandomValues(cryptoStor);

 

В результаті ви отримаєте в консолі такі приблизні значення:

//Uint16Array(5) [23386, 29207, 40761, 23872, 54616] – приклад результату

 

 

API веб-криптографії має хорошу підтримку в сучасних браузерах, хоча в деяких випадках потрібне використання префікса постачальника.

На сьогодні все, дякуємо за увагу!

 

Recent Posts

Антидетект-браузери для початківців: що це таке (на прикладі Dolphin чи AdsPower) і як їх правильно поєднати з мобільними проксі

Анонімність та розділення акаунтів є базовою потребою для співробітників, що займаються арбітражем трафіку, SMM чи…

6 днів ago

Коли точно настав час здати старий каталізатор для вигідного продажу

Деякі запчастини в автомобілях ми експлуатуємо доти, доки вони повністю не вийдуть з ладу. Однак…

1 тиждень ago

Як онлайн-моніторинг цін конкурентів допомагає бізнесу у 2026 році

В 2026 році конкуренція в e-commerce стала жорсткою як ніколи. Клієнти вибирають не тільки за…

3 тижні ago

5 аграрних помилок, які коштують врожаю, але про них рідко говорять

Урожай найчастіше втрачають не через аномальні зміни погоди, а через дрібні рішення, які здаються неважливими.…

1 місяць ago

Музичні інструменти, історія, класифікація та роль у культурі людства

Музичні інструменти супроводжують людство протягом усієї його історії. Вони з'явилися задовго до писемності і стали…

1 місяць ago

VR-продакшн, повний цикл створення віртуальної реальності

VR-продакшн сьогодні є окремим напрямком у цифровому виробництві, що поєднує технології віртуальної реальності, 3D-графіку, програмування,…

1 місяць ago