php 例子 测评系统,实例展示JS实现简单的选择题测评系统

本文给大家分享js实现简单的选择题测评系统实例代码,非常不错,具有参考借鉴价值,需要的朋友参考下吧

包含内容: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.在读文件Employee.txt 时,可以直接使用该文件作为参数的类是()

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) {

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;

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);

}

考试结束!




结果如下图:

018592559f7fe39f9e005ddda73c2840.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值