Get random X items from array in javascript(在Java脚本中从数组中获取随机X个项目)
                            本文介绍了在Java脚本中从数组中获取随机X个项目的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
                        
                        问题描述
我有以下使用测试数据的小提琴,我正在使用$.each查看数据
我可以遍历任何问题,但我想遍历数据,然后从其中随机获取3个对象。
任何提示或技巧都会有所帮助:
https://jsfiddle.net/inkedraskal/pah44qv6/
$.each(testData,function(x, blah){
    //console.log(blah._id);
  //this gets each objects id & picture, but I want to get 3 random objects, and their corresponding data
  var activeValue = blah._id,
        pictureValue = blah.picture;
  var markUp = '';
  markUp += activeValue + pictureValue;
  console.log(markUp);
});
对于下面的问题,它们需要唯一**
推荐答案
我们可以创建getRandomEntry()函数,该函数将使用Math.random()函数返回数组的一个元素。我们将创建一个循环,它将在每次迭代时接受随机条目。
function getRandomEntry() {
  return testData[Math.round(Math.random() * (testData.length - 1))];
}
for (var i=0; i<3; i++) {
  var entry = getRandomEntry();
  console.log(entry._id, entry.picture);
}
如果每次都需要唯一的条目。您可以将随机条目保存在单独的数组中,并检查新的条目是否唯一。
var randomEntries = [];
function getRandomEntry() {
  return testData[Math.round(Math.random() * (testData.length - 1))];
}
function entryExists(entry) {
  return randomEntries.indexOf(entry) > -1;
}
for (var i=0; i<3; i++) {
  var entry;
  do {
    entry = getRandomEntry();
  } while(entryExists(entry))
  randomEntries.push(entry);
  console.log(entry._id, entry.picture);
}
                        这篇关于在Java脚本中从数组中获取随机X个项目的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
				 沃梦达教程
				
			本文标题为:在Java脚本中从数组中获取随机X个项目
				
        
 
            
        
             猜你喜欢
        
	     - Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
 - CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
 - Flexslider 箭头未正确显示 2022-01-01
 - 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
 - Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
 - Fetch API 如何获取响应体? 2022-01-01
 - 400或500级别的HTTP响应 2022-01-01
 - addEventListener 在 IE 11 中不起作用 2022-01-01
 - 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
 - 失败的 Canvas 360 jquery 插件 2022-01-01
 
						
						
						
						
						