用HTML+CSS+JavaScript制作一个能实现答题且答题结束统计分数功能的网页

用HTML+CSS+JavaScript制作一个能实现答题且答题结束统计分数功能的网页,JavaScript代码怎么写

 

帮助到你能点个采纳吗,问题自己整下~结果页答案也需要整理如果改过

qustions.html

<html>
<head>
    <title>考试系统</title>
    <meta charset="utf-8">
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
    <script type="text/javascript">
        function getjson() {
            var radio = new Array();
            for (var i = 1; i <= 5; i++) {//获取radio的值
                var radio_name = new String("radio_" + i);
                radio[i - 1] = $('input:radio[name=' + radio_name + ']:checked').val()
            }
            for (var i = 1; i <= 2; i++) {//获取checkbox的的输入
                var checkbox_name = new String("checkbox_" + i);
                var chk_value = [];
                $('input:checkbox[name=' + checkbox_name + ']:checked').each(function () {
                    chk_value.push($(this).val());
                });
                radio[i + 4] = "";//置为空
                for (var j = 0; j < chk_value.length; j++) {
                    radio[i + 4] = radio[i + 4] + chk_value[j];
                }
            }
            //数组转json串
            var json = JSON.stringify(radio);
            return json;
        }
        function my_confirm() {
            var json = getjson();
            var msg = "您真的答案是:" + json + ",是否确认提交";
            if (confirm(msg) == true) {
                window.location.href = "result.html?radio=" + 5 + "checkbox=" + 2 + "&json=" + json;
            } else {
                return false;
            }
        }
        $(function () {
            var m = 1;
            var s = 10;
            setInterval(function () {
                if (m >= 0) {
                    if (s < 10) {
                        $('#time').html("剩余时间:" + m + ':0' + s);
                    } else {
                        $('#time').html("剩余时间:" + m + ':' + s);
                    }
                    s--;
                    if (s < 0) {
                        s = 59;
                        m--;
                    }
                    if (m == 0 && s < 1) {
                        window.location.href = "result.html?radio=" + 5 + "checkbox=" + 2 + "&json=" + getjson();
                    }
                }
            }, 1000)
        })
    </script>
</head>
<body>
<h3 style="float: left">2016--2017学年期末测试题</h3>

<div id="time" style="color:red;float: right;margin: 12px 20px 0 0;padding: 0 0 0 0;font-size: xx-large"></div>

<br/><br/><br/>
<hr/>
<h4>一、单选题(每题12分,满分60分)</h4>
1.当方法遇到异常又不知如何处理时,下列() 做法是正确的。<br>
<input type="radio" name="radio_1" value="A">A、捕获异常<br>
<input type="radio" name="radio_1" value="B">B、抛出异常<br>
<input type="radio" name="radio_1" value="C">C、声明异常<br>
<input type="radio" name="radio_1" value="D">D、嵌套异常<br>
2.下列说法错误的是() <br>
<input type="radio" name="radio_2" value="A">A、在java中一个类被声明为final类型,表示该类不能被继承。<br>
<input type="radio" name="radio_2" value="B">B、当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,这叫引用传递。<br>
<input type="radio" name="radio_2" value="C">C、一个类不能既被声明为 abstract,又被声明为final。<br>
<input type="radio" name="radio_2" value="D">D、方法的覆盖(Overriding)和重载(Overloading)是Java多态性的表现,他们没有区别。<br>
3.下列创建数组的方法哪个是错误的? <br>
<input type="radio" name="radio_3" value="A">A、Date[] arr = new Date[5];<br>
<input type="radio" name="radio_3" value="B">B、Date arr[] = new Date[];<br>
<input type="radio" name="radio_3" value="C">C、Date arr[][] = new Date[4][5];<br>
<input type="radio" name="radio_3" value="D">D、Date arr[][] = new Date[4][];<br>
4.在读文件Employee.txt 时,可以直接使用该文件作为参数的类是() <br>
<input type="radio" name="radio_4" value="A">A、BufferedReader<br>
<input type="radio" name="radio_4" value="B">B、FileInputStream<br>
<input type="radio" name="radio_4" value="C">C、DataOutputStream<br>
<input type="radio" name="radio_4" value="D">D、DataInputStream<br>
5.下列关于线程的说法中,错误的是? <br>
<input type="radio" name="radio_5" value="A">A、线程必须通过方法start() 来启动。<br>
<input type="radio" name="radio_5" value="B">B、线程创建后,其优先级是可以改变的。<br>
<input type="radio" name="radio_5" value="C">C、实现Runnable接口或者从Thread类派生的线程类没有区别。<br>
<input type="radio" name="radio_5" value="D">D、当对象用synchronized 修饰时,表明该对象在任一时刻只能由一个线程访问。<br>
<br/>
<h4>二、多选题(每题20分,满分40分,错选、少选、多选不得分)</h4>
6.下列说法正确的是() <br>
<input type="checkbox" name="checkbox_1" value="A">A、在java中一个类被声明为final类型,表示该类不能被继承。<br>
<input type="checkbox" name="checkbox_1" value="B">B、当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,这叫引用传递。<br>
<input type="checkbox" name="checkbox_1" value="C">C、一个类不能既被声明为 abstract,又被声明为final。<br>
<input type="checkbox" name="checkbox_1" value="D">D、方法的覆盖(Overriding)和重载(Overloading)是Java多态性的表现,他们没有区别。<br>
7.当方法遇到异常又不知如何处理时,下列() 做法是不正确的。<br>
<input type="checkbox" name="checkbox_2" value="A">A、捕获异常<br>
<input type="checkbox" name="checkbox_2" value="B">B、抛出异常<br>
<input type="checkbox" name="checkbox_2" value="C">C、声明异常<br>
<input type="checkbox" name="checkbox_2" value="D">D、嵌套异常<br>
<hr/>
<input type="button" onclick="my_confirm()" value="考试完成">
</body>
</html>

result.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>考试结果</title>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
    <script>

        //获取url中的参数
        function getUrlParam(name) {
            var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
            var r = window.location.search.substr(1).match(reg); //匹配目标参数
            if (r != null) return unescape(r[2]);
            return null; //返回参数值
        }
        function showResult() {
            var answer = ["B", "D", "B", "B", "D", "ABC", "ACD"];//标准答案
            var answer_score = [12, 12, 12, 12, 12, 20, 20];//答案的分数
            var user_answer = JSON.parse(getUrlParam("json"));//获取用户答案
            var radio_num = parseInt(getUrlParam("radio"));//获取单选个数
            var checkbox_num = parseInt(getUrlParam("checkbox"));//获取多选个数
            var radio_result = 0;//单选分数
            var checkbox_result = 0;//多选分数
            var radio_right_num = 0;//单选答对个数
            var checkbox_right_num = 0;//多选答对个数
            var result = 0;//总分数
            var user_answer_result = new Array();//用户没到题的答题情况
            for (var i = 0; i < user_answer.length; i++) {
                if (user_answer[i] == answer[i]) {
                    if (i < radio_num) {
                        radio_result = radio_result + answer_score[i];
                        radio_right_num++;
                    } else {
                        checkbox_result = checkbox_result + answer_score[i];
                        checkbox_right_num++;
                    }
                    user_answer_result[i] = "正确";
                } else {
                    user_answer_result[i] = "错误";
                }
            }
            result = checkbox_result + radio_result;
            //结果展示
            var show_result1;
            var show_result2;
            var show_result3;
            var show_result4;
            var show_result5;
            var show_result6;
            show_result1 = "你的答案结果为:";
            for (var i = 0; i < user_answer.length; i++) {
                show_result1 = show_result1 + (i + 1) + ":" + user_answer_result[i] + ";&nbsp;";
            }
            show_result2 = "总题目个数:" + user_answer.length;
            show_result3 = "答对单选题题目个数:" + radio_right_num + ";&nbsp;得分:" + radio_result;
            show_result4 = "答对多选题题目个数:" + checkbox_right_num + ";&nbsp;得分:" + checkbox_result;
            show_result5 = "答错题目个数:" + (user_answer.length - radio_right_num - checkbox_right_num);
            show_result6 = " 本次考试总成绩为:" + result;
            $("p#show_result1").html(show_result1);
            $("p#show_result2").html(show_result2);
            $("p#show_result3").html(show_result3);
            $("p#show_result4").html(show_result4);
            $("p#show_result5").html(show_result5);
            $("p#show_result6").html(show_result6);
        }
    </script>
</head>
<body>
<h2>考试结束!</h2>
<hr/>
<p id="show_result1">
<p>
<hr/>
<p id="show_result2"></p>
<p id="show_result3"></p>
<p id="show_result4"></p>
<p id="show_result5"></p>
<hr/>
<p id="show_result6"></p>
<script>
showResult()
</script>
</body>
</html>

 

<!DOCTYPE html>
<html>
<head>
    <title>答题统计分数</title>
    <style>
        body {
            font-family: sans-serif;
            font-size: 14px;
        }
        #questions {
            padding: 10px;
            border-radius: 5px;
            border: 1px solid #ccc;
        }
        #questions h2 {
            margin-top: 0;
            font-size: 16px;
        }
        #questions ul {
            list-style-type: none;
            padding: 0;
        }
        #questions li {
            margin-bottom: 10px;
        }
        #questions li label {
            display: block;
        }
        #btn {
            display: block;
            margin-top: 20px;
            padding: 10px;
            background-color: #0099cc;
            color: #fff;
            border-radius: 5px;
            text-align: center;
            cursor: pointer;
        }
        #result {
            display: none;
            padding: 10px;
            margin-top: 20px;
            border-radius: 5px;
            border: 1px solid #ccc;
            font-size: 16px;
        }
    </style>
</head>
<body>
    <div id="questions">
        <h2>请回答以下问题:</h2>
        <ul>
            <li>
                <label>1.以下哪个不是编程语言?</label>
                <input type="radio" name="q1" value="A" />A.Java
                <input type="radio" name="q1" value="B" />B.Word
                <input type="radio" name="q1" value="C" />C.Python
                <input type="radio" name="q1" value="D" />D.C++
            </li>
            <li>
                <label>2.以下哪个不是操作系统?</label>
                <input type="radio" name="q2" value="A" />A.Windows
                <input type="radio" name="q2" value="B" />B.Excel
                <input type="radio" name="q2" value="C" />C.Linux
                <input type="radio" name="q2" value="D" />D.Mac OS
            </li>
            <li>
                <label>3.以下哪个不是数据库?</label>
                <input type="radio" name="q3" value="A" />A.MySQL
                <input type="radio" name="q3" value="B" />B.Oracle
                <input type="radio" name="q3" value="C" />C.Word
                <input type="radio" name="q3" value="D" />D.SQL Server
            </li>
        </ul>
        <input type="button" id="btn" value="提交" />
    </div>
    <div id="result">
        您的得分是:<span id="score">0</span></div>
    <script>
        var btn = document.getElementById('btn');
        var result = document.getElementById('result');
        var score = document.getElementById('score');
        btn.onclick = function(){
            var q1 = document.getElementsByName('q1');
            var q2 = document.getElementsByName('q2');
            var q3 = document.getElementsByName('q3');
            var s = 0;
            if(q1[1].checked){
                s += 25;
            }
            if(q2[2].checked){
                s += 25;
            }
            if(q3[0].checked){
                s += 25;
            }
            score.innerHTML = s;
            result.style.display = 'block';
        }
    </script>
</body>
</html>

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

后端代码怎么写啊,这个在服务器里跑不起来