我正在进行互动测验,我遇到了一个问题。我需要添加一些时间限制(让我们说5s用于测试目的),这样当时间用完时,无论用户在哪个阶段,测验都应跳到结果部分,并将所有未回答的问题计算为错。
这是我的代码:
jQuery(function(){
var tourismQuiz = {
answers: { q1: 'd', q2: 'd', q3: 'a', q4: 'c', q5: 'a', q6: 'd', q7: 'd', q8: 'a', q9: 'c', q10: 'a' },
questionLenght: 10,
checkAnswers: function() {
var arr = this.answers;
var ans = this.userAnswers;
var resultArr = []
for (var p in ans) {
var x = parseInt(p) + 1;
var key = 'q' + x;
var flag = false;
if (ans[p] == 'q' + x + '-' + arr[key]) {
flag = true;
}
else {
flag = false;
}
resultArr.push(flag);
}
return resultArr;
},
init: function(){
jQuery('.btnNext').click(function(){
if (jQuery('input[type=radio]:checked:visible').length == 0) {
return false;
}
jQuery(this).parents('.questionContainer').fadeOut(500, function(){
jQuery(this).next().fadeIn(500);
});
var el = jQuery('#progress');
el.width(el.width() + 60 + 'px');
});
jQuery('.btnPrev').click(function(){
jQuery(this).parents('.questionContainer').fadeOut(500, function(){
jQuery(this).prev().fadeIn(500)
});
var el = jQuery('#progress');
el.width(el.width() - 60 + 'px');
})
jQuery('.btnShowResult').click(function(){
var arr = jQuery('input[type=radio]:checked');
var ans = tourismQuiz.userAnswers = [];
for (var i = 0, ii = arr.length; i < ii; i++) {
ans.push(arr[i].getAttribute('id'))
}
})
jQuery('.btnShowResult').click(function(){
jQuery('#progress').width(300);
jQuery('#progressKeeper').hide();
var results = tourismQuiz.checkAnswers();
var resultSet = '';
var trueCount = 0;
for (var i = 0, ii = results.length; i < ii; i++){
if (results[i] == true) {
trueCount = trueCount + 2;
} else {
trueCount = trueCount - 1;
}
resultSet += '<div> Question ' + (i + 1) + ' is ' + results[i] + '</div>'
if (trueCount <= 5) {
jQuery("body").css("background-color", "red");
} else {
jQuery("body").css("background-color", "green");
}
}
resultSet += '<div class="totalScore">Your total score is ' + trueCount + ' / 20</div>'
jQuery('#resultKeeper').html(resultSet).show();
})
}
};
tourismQuiz.init();
})
因此,如果时间用完,应该执行按此按钮执行的功能,而不是等待用户按.btnShowResult
完成测试。
答案 0 :(得分:1)
Checkout window.setTimeout,这应该让你开始: 在指定的延迟后调用函数或执行代码片段。
所以你想给用户一些时间(5000毫秒)来回答一个问题,然后再将它们转发到下一个问题,例如:
//Psuedocode:
var askNextQuestion, timer ;
askNextQuestion = function(){
// ... render the question or do whatever
timer = setTimeout(askNextQuestion, 5000);
// .. do any clean up and check to see if it's the last question etc.
};
askNextQuestion();
我不会试图比Mozilla更好地解释它! https://developer.mozilla.org/en/docs/DOM/window.setTimeout
答案 1 :(得分:0)
使用setTimeout
作为init function
的最后一条语句,并将jQuery('.btnShowResult').
与setTimeout
绑定的功能写入单独的函数中,并将其添加到setTimeout("show_result", 20000);
.clearTimeout(timeoutVariable)
此外,如果用户在时间限制内按下按钮,则使用例如{{1}}来重置超时。
答案 2 :(得分:0)
保存问题出现时的时间戳,然后将其与用户提交答案的时间戳进行比较。如果比较时间超过限制,则答案已经迟到了。
倒计时的介绍可能只是图形化,例如。一个条形宽度的CSS3动画,从100%到0%。以秒为单位交换“缓慢”的时间限制。
$("#bar").animate({ width:'0%' },'slow');
检查http://www.w3schools.com/css3/css3_animations.asp以获取有关设置动画的提示!