从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)]]); } 但是如

我需要从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)]]);
}

但是如何从这个对象打印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()函数。这样,您就可以在任何浏览器中获取密钥数组