很抱歉,如果这是一个重复的问题,我四处搜索却找不到答案。
我试图在每次点击时生成一个新的随机数。到目前为止,只有第一个数字是随机的,随后的每次点击都不会发生任何事情。我认为 getRandomNumber 函数只计算一次,这就是为什么我得到相同的数字。
$(document).ready(function(){
var index = 0;
function getRandomNumber(){
shuffle = function(o){
for(var j, x, i = o.length; i; j = parseInt(Math.random() * i), x = o[--i], o[i] = o[j], o[j] = x);
return o;
};
var randorder = shuffle([0,1,2,3,4]);
return randorder[index++];
}
$("#button2").click(function(){
var gameq = new Array();
gameq[0] = "Question 1 ?";
gameq[1] = "Question 2 ?";
gameq[2] = "Question 3 ?";
gameq[3] = "Question 4 ?";
gameq[4] = "Question 5 ?";
$("#question").replaceWith('<h5>' + gameq[getRandomNumber()] + '</h5>')
});
});
最佳答案
您只需在第一次杀死您的#question
元素即可。尝试像这样更改最后一行:
$("#question").replaceWith('<h5 id="question">' + gameq[getRandomNumber()] + '</h5>');
或者也许这对你也有好处:
$("#question").html('<h5>' + gameq[getRandomNumber()] + '</h5>');
关于javascript - 单击时生成相同的随机数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17401277/