ChatGPT解决这个技术问题 Extra ChatGPT

从 JavaScript 数组中获取随机项 [重复]

这个问题在这里已经有了答案:Getting a random value from a JavaScript array (27 answers) Closed 7 years ago。

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

如何从 items 获取随机项目?

答案不会涉及 jQuery
我从来没有见过对一个问题有这么多完全相同的回答......
伟大的思想,@Blindy
我找到了一种涉及 jQuery 的方法! (见我的第二个答案)
这个问题与 Getting random value from an array 完全相同,但 Mighty Mods 已经 3 年多没有费心去关闭它了。相反,它们会关闭 "unconstructive" questions with hundreds of votes

C
Corey
var item = items[Math.floor(Math.random()*items.length)];

Math.random() 永远不会是 1,也不应该是 1。 最大的索引应该总是比长度小 1,否则会出现 undefined 错误。
优雅的解决方案。我对其进行了测试:var items = ["a","e","i","o","u"] var objResults = {} for(var i = 0; i < 1000000; i++){ var randomElement = items[Math.floor(Math.random()*items.length)] if (objResults[randomElement]){ objResults[randomElement]++ }else{ objResults[randomElement] = 1 } } console.log(objResults) 经过 1000000 次迭代后,结果非常随机:Object {u: 200222, o: 199543, a: 199936, e: 200183, i: 200116}
@AnkitPatial:这是一种“打乱”数组的方法,但问题是关于从数组中随机选择的元素。有很大的不同。
@virus Math.round 不是 Math.floor 的有效替代品。使用 round 会导致意外引用未定义的索引,例如 Math.random() 为 0.95 而 items.length 为 5。Math.round(0.95*5) 为 5,这将是无效索引。在您的示例中,floor(random) 将始终为零。
不错的答案。你可以更短:items[items.length * Math.random() | 0] :)
c
chim

使用下划线(或 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];

仅对一个功能使用下划线或 lodash 会有点过分,但如果您正在执行任何复杂的 js 功能,那么它可以节省数小时甚至数天。
现在下划线也有更好的选择这个_.sample([1, 2, 3, 4, 5, 6])
您可能会在任何实际项目中使用 _。这不是一件坏事。
lodash 在 npm 上进行了模块化,因此如果需要,您可以只安装 sample 函数:npmjs.com/package/lodash.sample
我的信条是在任何项目中使用尽可能少的库。话虽如此,我最终总是使用 lodash。太方便了 不用
J
JUDE DAILY

1.解决方案:定义Array原型

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

这将适用于内联数组

[2,3,5].random()

当然还有预定义的数组

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

2. 解决方案:定义接受列表并返回元素的自定义函数

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


get_random([2,3,5])

@EvanCarroll 更好地参考一个有用的链接,而不是对诸如编码风格之类的主观概念投反对票,这不会使答案无效或“无用”! stackoverflow.com/questions/14034180/…
赞成是因为反对向 Array.prototype 添加一些东西对没有解释的任何人都没有用。
向 Array.prototype 添加新函数的问题与添加全局变量的问题相同——某人/其他人可能对不同的事物使用相同的“名称”——这可能会导致微妙的混乱
这次真是万分感谢。比键入整个香草公式或在代码多次需要它时调用自定义函数要有用。至于对冲突的有效关注,这就是命名空间的用途:ns.ns_ 格式(如果适用)。
@Schmoo 我刚刚遇到了其中一种“微妙的混乱”情况。我将原型的名称缩短为“rand”。然后突然在 for (let i in arr) 循环期间,它迭代所有预期的索引,并迭代“rand”的索引。不得不切换到 for (let i=0,l=arr.length;i<l;i++) 循环来修复它。
A
Alnitak

如果你真的必须使用 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/ 的工作演示


@neoascetic 该行的重点是从数组中选择一个元素不是 jQuery 问题,它是通用 JS。
@damd re:您建议的编辑 - 这显然是不正确的,因为在 IIFE 中 定义 插件和使用插件之间存在明显的区别。但是,为了保持一致性,我已将用法行中的 $ 替换为 jQuery
确实。每行平均少于 3 个链接方法,并且每行至少使用一次 $,因此它没有足够的 jQuery。
这不是需要 jQuery 的问题。
K
K-Gun

这是另一种方式:

function rand(items) {
    // "~~" for a closest "int"
    return items[~~(items.length * Math.random())];
}

或者如下 @1248177 推荐的:

function rand(items) {
    // "|" for a kinda "int div"
    return items[items.length * Math.random() | 0];
}

那个疯狂的 ~~ 是什么?以前在 JS 中从未见过。
@hatboysam:do a search - 它本质上将操作数转换为最接近的整数。
实际上,它会将其向下取整,例如 Math.floor
不错的答案。你仍然可以更短:items[items.length * Math.random() | 0] :)
“实际上,它像 Math.floor 一样将其四舍五入”@programmer5000。它实际上向 0 舍入,即 ~~(-1.5) 计算结果为 -1,而不是 Math.floor 给出的 -2。
g
gen_Eric
var random = items[Math.floor(Math.random()*items.length)]

P
Peter Mortensen

jQuery 就是 JavaScript!它只是一个 JavaScript 框架。因此,要找到一个随机项目,只需使用普通的旧 JavaScript,例如,

var randomItem = items[Math.floor(Math.random()*items.length)]

I
Ivan Pirog
// 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];

甚至射手(JosédB.):

let item = items.sort(() => 0.5 - Math.random())[0];

items[1] 是第二项,第一项是 items[0]
哦对不起。因为项目[0]
这不会给你一个统一的洗牌:sroucheray.org/blog/2009/11/…
下一个射手:let item = items.sort(() => 0.5 - Math.random())[0];
也很高兴知道 thar 算法的复杂性:)
B
Blindy
var rndval=items[Math.floor(Math.random()*items.length)];

M
Martijn Pieters
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 Function: Random Number Generator


仅供参考,这可能是一行:Math.floor(Math.random() * (max - min + 1)) + min
A
Aayan L

如果您使用的是 node.js,则可以使用 unique-random-array。它只是从数组中随机选择一些东西。


P
Peter Mortensen

另一种方法是向 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)

数组有一个内置的长度属性 - 为什么将它作为参数传递?!
我想我的意思是你可以传入任何你想要的长度,而不仅仅是数组的长度——如果你只是想随机化前两个条目,你可以在不改变方法的情况下将长度设置为 2。我认为将长度属性作为参数传递没有性能问题,但我可能错了
像这样扩展宿主对象通常不是一个好主意。您可能会因行为与您的行为不同的客户端未来的 Array.random 实现而绊倒,从而破坏未来的代码。您至少可以在添加之前检查以确保它不存在。
N
Nicolas
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;
  }
}

在许多评论中指出,这是一种不好的做法,请参阅stackoverflow.com/questions/14034180/… :)
我只是更改声明以避免显示错误的约定方法声明