JS实现简单的选择题测评系统代码思路详解(demo

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

--------------------------------------------------------------------------------

result.html

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wygjzx.html