功能需求:
项目:基于浏览器的测评系统(答题系统)
需求:对答题时间进行控制,运用前端知识对测评进行倒计时功能。
(jquery-1.8.3.min.js/jquery.cookie.js)js框架,可以在jquery官网下载。
?
var surplusSeconds;// 剩余时间(秒) var si;// 倒计时排程 var totalMins = 120;// 试卷总答题时限(分钟) // 将剩余秒放入cookie中,便于关闭浏览器后,再打开后进入答题系统后,接着上次倒计时时间开始计时 function setSurplusSecondsToCookie(){ var cookietime = new Date(); cookietime.setTime(cookietime.getTime() + (60 * 60 * 1000 * 5));// coockie保存5小时 $.cookie("surplusSeconds", surplusSeconds, {expires:cookietime}); } // 从cookie中读出剩余秒 function getSurplusSecondsFromCookie(){ return $.cookie("surplusSeconds"); } // 倒计时 function timeoutFn(){ if(surplusSeconds == 0){// 剩余秒为0,自动提交试卷 submitPaper(); clearInterval(si); // 停止倒计时排程 $.cookie("surplusSeconds", null);// 清空cookie中的剩余秒 return; }else if(surplusSeconds == 5 * 60){ // 还剩5分钟,给出提醒 }else if(surplusSeconds == 15 * 60){ // 还剩15分钟,给出提醒 } surplusSeconds--; setSurplusSecondsToCookie(); // 设置剩余时间的显示 var seconds = surplusSeconds % 60; var surplusTimeHtml = Math.floor(surplusSeconds / 60) + "分" + (seconds < 10 ? ("0" + seconds) : (seconds)) + "秒"; $("#surplusTime").html(surplusTimeHtml); } $(function(){ if(getSurplusSecondsFromCookie()){// 若cooki存在剩余秒,则此剩余秒开始倒计时 surplusSeconds = getSurplusSecondsFromCookie(); }else{ surplusSeconds = totalMins * 60; } si = setInterval(timeoutFn, 1000); // 启动倒计时 });
??
?
?