私はオンライン試験システムを作成します。javascript - カウントダウンタイマーの起動と停止
私の質問:カウントダウンタイマーの開始といつかブラウザーページを閉じるよりも、適用ボタンをクリックします。同じテスト名をクリックした後、カウントダウンタイマーを続行し、開始を開始しません。 スクリーンショット
の下ビュー:
<h2><p style="float: right" id="countdown"></p></h2>
<a href="<?php echo base_url(); ?>student/Examinations/apply_examinations/<?php echo $value['examination_test_id']; ?>" class="btn btn-primary" id="apply" onclick="resetCountdownInLocalStorage();">Apply</a>
<script>
$(document).ready(function() {
$examination_test_id = $("#examination_test_id").val();
$time_limit = $("#time_limit").val();
var d = new Date($time_limit);
var hours = d.getHours();
var minute = d.getMinutes();
var minutes = hours * 60 + minute;
var seconds = 60 * minutes;
if (typeof (Storage) !== "undefined") {
if (sessionStorage.seconds) {
seconds = sessionStorage.seconds;
}
}
function secondPassed() {
var hours = Math.floor(seconds/3600);
var minutes = Math.floor((seconds - (hours * 3600))/60);
// var remainingSeconds = seconds - (hours * 3600) - (minutes * 60);
var remainingSeconds = seconds % 60;
if (remainingSeconds < 10) {
remainingSeconds = "0" + remainingSeconds;
}
if (minutes < 10) {
minutes = "0" + minutes;
}
if (typeof (Storage) !== "undefined") {
sessionStorage.setItem("seconds", seconds);
}
document.getElementById('countdown').innerHTML = hours + ":" + minutes + ":" + remainingSeconds;
if (seconds == 0) {
clearInterval(myVar);
document.getElementById('countdown').innerHTML = alert('Timeout');
window.location.href = base_url + "student/Examinations/check_answer/" + $examination_test_id;
if (typeof (Storage) !== "undefined") {
sessionStorage.removeItem("seconds");
}
} else {
seconds--;
}
}
var myVar = setInterval(secondPassed, 1000);
});
function resetCountdownInLocalStorage() {
sessionStorage.removeItem("seconds");
}
</script>
私は現在のフォームであなたの質問を本当に理解していません。しかし、ブラウザを閉じて再度開くと、あなたの「状態」が失われます。新しいプログラム全体を効果的に実行しています。ページを開いた後に「続行」したい場合は、その情報をどこかに保存する必要があります –
@DylanMeeusコードを書き込んでください – kishan123
@DylanMeeus最初にスクリーンショットを見て、適用ボタンをクリックしてからタイマーを開始してブラウザのページを閉じる数分、同じ試験名をクリックしてからカウントダウンタイマーを開始し、開始しないでください – kishan123