html选择题代码,JS实现简单的选择题测评系统代码思路详解
(demo)
包含内容:JS封装表单,JS校验表单
说是测评系统,感觉只能算是⼀个⼩⼩的Demo,很⽔,,没有数据库库,,仅使⽤JS做简单的选择题测评系统
--------------------------------------------------------------------------------
⼀、设计思路
表单封装:
【1】由于采⽤JS封装提交所以,不需要form标签
【2】放置多个input标签,作为输⼊项
【3】编写JS获取输⼊项,并通过get⽅式提交到另⼀个页⾯
校验表单(显⽰结果)
【1】获取get传⼊的参数
【2】通过JS解析
【3】显⽰到相应位置
--------------------------------------------------------------------------------
⼆、参考源码如下
request.html
考试系统
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)
2016--2017学年期末测试题
⼀、单选题(每题12分,满分60分)
1.当⽅法遇到异常⼜不知如何处理时,下列() 做法是正确的。
A、捕获异常
B、抛出异常
C、声明异常
D、嵌套异常
2.下列说法错误的是()
A、在java中⼀个类被声明为final类型,表⽰该类不能被继承。
B、当⼀个对象被当作参数传递到⼀个⽅法后,此⽅法可改变这个对象的属性,这叫引⽤传递。
C、⼀个类不能既被声明为 abstract,⼜被声明为final。
D、⽅法的覆盖(Overriding)和重载(Overloading)是Java多态性的表现,他们没有区别。
3.下列创建数组的⽅法哪个是错误的?
A、Date[] arr = new Date[5];
B、Date arr[] = new Date[];
C、Date arr[][] = new Date[4][5];
D、Date arr[][] = new Date[4][];
4.在读⽂件 时,可以直接使⽤该⽂件作为参数的类是()
A、BufferedReader
B、FileInputStream
C、DataOutputStream
D、DataInputStream
5.下列关于线程的说法中,错误的是?
A、线程必须通过⽅法start() 来启动。
B、线程创建后,其优先级是可以改变的。
C、实现Runnable接⼝或者从Thread类派⽣的线程类没有区别。
D、当对象⽤synchronized 修饰时,表明该对象在任⼀时刻只能由⼀个线程访问。
⼆、多选题(每题20分,满分40分,错选、少选、多选不得分)
6.下列说法正确的是()
A、在java中⼀个类被声明为final类型,表⽰该类不能被继承。
B、当⼀个对象被当作参数传递到⼀个⽅法后,此⽅法可改变这个对象的属性,这叫引⽤传递。
C、⼀个类不能既被声明为 abstract,⼜被声明为final。
D、⽅法的覆盖(Overriding)和重载(Overloading)是Java多态性的表现,他们没有区别。
7.当⽅法遇到异常⼜不知如何处理时,下列() 做法是不正确的。
A、捕获异常
B、抛出异常
C、声明异常
D、嵌套异常
--------------------------------------------------------------------------------
result.html
考试结果
//获取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) {html radio点击变颜
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] + "; ";
}
show_result2 = "总题⽬个数:" + user_answer.length;
show_result3 = "答对单选题题⽬个数:" + radio_right_num + "; 得分:" + radio_result;
show_result4 = "答对多选题题⽬个数:" + checkbox_right_num + "; 得分:" + checkbox_result; sh
ow_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);
}
考试结束!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。