日期:2014-05-16  浏览次数:20435 次

js实现倒计时功能

功能需求:

项目:基于浏览器的测评系统(答题系统)

需求:对答题时间进行控制,运用前端知识对测评进行倒计时功能。

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); // 启动倒计时
});

??

?

?