从javascript对象打印5个随机键/值对
我需要从javascript对象中选择并打印5个随机键/值对。目前,我对对象进行如下迭代:从javascript对象打印5个随机键/值对,javascript,jquery,Javascript,Jquery,我需要从javascript对象中选择并打印5个随机键/值对。目前,我对对象进行如下迭代: $.each(object, function(key, val) { ... }); var i, result = []; for (i = 0; i < 5; i++) { result.push(object[keys[Math.floor(Math.random() * length)]]); } 但是如
$.each(object, function(key, val) {
...
});
var i,
result = [];
for (i = 0; i < 5; i++) {
result.push(object[keys[Math.floor(Math.random() * length)]]);
}
但是如何从这个对象打印5个随机键值对呢?问题是我不知道这个对象的长度,所以我无法通过计算一个随机的起始位置来计算它&从那里开始提取5对。查找对象中的项目数并不困难。您只需要使用
Object.keys
。这将获取一个数组,其中包含对象中的所有键名
var keys = Object.keys(object),
length = keys.length;
然后,您可能希望随机选择项目,可能如下所示:
$.each(object, function(key, val) {
...
});
var i,
result = [];
for (i = 0; i < 5; i++) {
result.push(object[keys[Math.floor(Math.random() * length)]]);
}
vari,
结果=[];
对于(i=0;i<5;i++){
结果.推(对象[键[Math.floor(Math.random()*长度)]);
}
查找对象中的项数并不困难。您只需要使用Object.keys
。这将获取一个数组,其中包含对象中的所有键名
var keys = Object.keys(object),
length = keys.length;
然后,您可能希望随机选择项目,可能如下所示:
$.each(object, function(key, val) {
...
});
var i,
result = [];
for (i = 0; i < 5; i++) {
result.push(object[keys[Math.floor(Math.random() * length)]]);
}
vari,
结果=[];
对于(i=0;i<5;i++){
结果.推(对象[键[Math.floor(Math.random()*长度)]);
}
对象。键(对象)
将为您提供一个对象中所有键的数组
var arrayOfAllKeys = Object.keys(object);
for(var i=0; i<5; i++){
var rnd = Math.floor(Math.random()*arrayOfAllKeys.length);
var objKey = arrayofAllKeys[rnd];
alert( "key: " + objKey + " value: " + object[objKey]);
}
Object.keys(Object)
将为您提供一个对象中所有键的数组
var arrayOfAllKeys = Object.keys(object);
for(var i=0; i<5; i++){
var rnd = Math.floor(Math.random()*arrayOfAllKeys.length);
var objKey = arrayofAllKeys[rnd];
alert( "key: " + objKey + " value: " + object[objKey]);
}
如果对象不是太大,则可以将数据复制到常规数组中并将其洗牌:
function fisherYates(array){
var i=array.length;
while(i--){
var j=Math.floor( Math.random() * (i+1) );
var tmp=array[i];
array[i]=array[j];
array[j]=tmp;
}
}
var object = {
firstName: "Jim",
lastName: "Smith",
city: "London",
country: "UK",
age: 33,
height: 170,
score: 123,
active: true
}
var deck = [];
$.each(object, function(key, val){
var o = {};
o[key] = val;
deck.push(o);
});
fisherYates(deck);
var selection = deck.slice(0, 5);
console.log(selection);
如果对象不是太大,则可以将数据复制到常规数组中并将其洗牌:
function fisherYates(array){
var i=array.length;
while(i--){
var j=Math.floor( Math.random() * (i+1) );
var tmp=array[i];
array[i]=array[j];
array[j]=tmp;
}
}
var object = {
firstName: "Jim",
lastName: "Smith",
city: "London",
country: "UK",
age: 33,
height: 170,
score: 123,
active: true
}
var deck = [];
$.each(object, function(key, val){
var o = {};
o[key] = val;
deck.push(o);
});
fisherYates(deck);
var selection = deck.slice(0, 5);
console.log(selection);
我添加了一个jQuery标记。如果那不是你的框架,请相应地重新标记。谢谢,我忘了提到这个!在迭代的每个步骤中,您可以生成一个介于1和对象长度之间的随机数。。。然后得到这个索引的值,我说我也不知道对象的长度。我添加了一个jQuery标记。如果那不是你的框架,请相应地重新标记。谢谢,我忘了提到这个!在迭代的每个步骤中,您可以生成一个介于1和对象长度之间的随机数。。。然后得到这个指数的值,我说我也不知道物体的长度。我遇到了
object.keys代码>但这不是跨浏览器解决方案@user01@lonesomeday我已经修复了文档以匹配您的链接锚:)@Jack Ha,我想这是一种方法@lonesomeday:我相信你粘贴的链接仅仅是为了firefox支持。不是吗?我遇到了Object.keys代码>但这不是跨浏览器解决方案@user01@lonesomeday我已经修复了文档以匹配您的链接锚:)@Jack Ha,我想这是一种方法@lonesomeday:我相信你粘贴的链接仅仅是为了firefox支持。不是吗?我遇到了Object.keys代码>但这不是跨浏览器解决方案@user01我已经更新了我的答案,生成了一个“costure”object.key()函数。这样,您就可以在我遇到的任何浏览器中获得键数组Object.keys代码>但这不是跨浏览器解决方案@user01我已经更新了我的答案,生成了一个“costure”object.key()函数。这样,您就可以在任何浏览器中获取密钥数组