web-dev-qa-db-ja.com

JavaScript配列からランダムなアイテムを取得する

var items = Array(523,3452,334,31,...5346);

itemsからランダムにアイテムを入手するにはどうすればいいですか?

738
James
var item = items[Math.floor(Math.random()*items.length)];
1616
Kelly

あなたが本当にmustこの問題を解決するためにjQueryを使わなければなりません:

(function($) {
    $.Rand = function(arg) {
        if ($.isArray(arg)) {
            return arg[$.Rand(arg.length)];
        } else if (typeof arg === "number") {
            return Math.floor(Math.random() * arg);
        } else {
            return 4;  // chosen by fair dice roll
        }
    };
})(jQuery);

var items = [523, 3452, 334, 31, ..., 5346];
var item = jQuery.Rand(items);

このプラグインは、配列が与えられた場合はランダムな要素を返し、数値が与えられた場合、または[0 .. n)から与えられた値、またはその他の任意の値が与えられた場合はランダム値を保証します。

さらに面白いことに、配列の長さに基づいて再帰的に関数を呼び出すことで配列の戻り値が生成されます。

で作業中のデモ - http://jsfiddle.net/2eyQX/

94
Alnitak

下線(またはloDash :)を使用してください。

var randomArray = [
   '#cc0000','#00cc00', '#0000cc'
];

// use _.sample
var randomElement = _.sample(randomArray);

// manually use _.random
var randomElement = randomArray[_.random(randomArray.length-1)];

あるいは、配列全体をシャッフルするには:

// use underscore's shuffle function
var firstRandomElement = _.shuffle(randomArray)[0];
86
chim
var random = items[Math.floor(Math.random()*items.length)]
37
Rocket Hazmat

1.解決策:配列プロトタイプを定義する

Array.prototype.random = function () {
  return this[Math.floor((Math.random()*this.length))];
}

それはインライン配列で動作します

[2,3,5].random()

そしてもちろん事前定義された配列

list = [2,3,5]
list.random()

2.解決策:リストを受け入れて要素を返すカスタム関数を定義する

get_random = function (list) {
  return list[Math.floor((Math.random()*list.length))];
} 

get_random([2,3,5])
36
dux

これはまた別の方法です。

function Rand(items) {
    return items[~~(items.length * Math.random())];
}
26
K-Gun

jQueryはJavaScriptです。それは単なるJavaScriptフレームワークです。そのため、ランダムなアイテムを見つけるには、単純な古いJavaScriptを使用します。例えば、

var randomItem = items[Math.floor(Math.random()*items.length)]
14
planetjones
var rndval=items[Math.floor(Math.random()*items.length)];
11
Blindy
var items = Array(523,3452,334,31,...5346);

function Rand(min, max) {
  var offset = min;
  var range = (max - min) + 1;

  var randomNumber = Math.floor( Math.random() * range) + offset;
  return randomNumber;
}


randomNumber = Rand(0, items.length - 1);

randomItem = items[randomNumber];

クレジット:

Javascript関数:乱数ジェネレータ

8
neebz
// 1. Random shuffle items
items.sort(function() {return 0.5 - Math.random()})

// 2. Get first item
var item = items[0]

短い:

var item = items.sort(function() {return 0.5 - Math.random()})[0];
7
Ivan

Node.jsを使用している場合は、 unique-random-array を使用できます。単に配列からランダムに何かを選びます。

4
Aayan L
const ArrayRandomModule = {
  // get random item from array
  random: function (array) {
    return array[Math.random() * array.length | 0];
  },

  // [mutate]: extract from given array a random item
  pick: function (array, i) {
    return array.splice(i >= 0 ? i : Math.random() * array.length | 0, 1)[0];
  },

  // [mutate]: shuffle the given array
  shuffle: function (array) {
    for (var i = array.length; i > 0; --i)
      array.Push(array.splice(Math.random() * i | 0, 1)[0]);
    return array;
  }
}
2
Nicolas

別の方法は、Arrayプロトタイプにメソッドを追加することです。

 Array.prototype.random = function (length) {
       return this[Math.floor((Math.random()*length))];
 }

 var teams = ['patriots', 'colts', 'jets', 'texans', 'ravens', 'broncos']
 var chosen_team = teams.random(teams.length)
 alert(chosen_team)
1
James Daly