【web前端】仅使用JS做简单的选择题测评系统

来源:互联网 发布:基础架构java 编辑:程序博客网 时间:2024/05/29 18:13

包含内容:JS封装表单,JS校验表单
说是测评系统,感觉只能算是一个小小的Demo,很水,,没有数据库库,,仅使用JS做简单的选择题测评系统



一、设计思路

表单封装:
【1】由于采用JS封装提交所以,不需要form标签
【2】放置多个input标签,作为输入项
【3】编写JS获取输入项,并通过get方式提交到另一个页面

校验表单(显示结果)
【1】获取get传入的参数
【2】通过JS解析
【3】显示到相应位置



二、参考源码如下

request.html

<html><head>    <title>考试系统</title>    <meta http-equiv="accept-charset" charset="utf-8">    <script src="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="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/><input type="button" onclick="showResult()" value="查看结果"><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></body></html>

结果如下图:
这里写图片描述