JS实现简单的选择题测评系统代码思路详解(demo)
发布时间 - 2026-01-11 03:05:09 点击率:次包含内容: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] + "; ";
}
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);
}
</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>
结果如下图:
总结
以上所述是小编给大家介绍的JS实现简单的选择题测评系统代码思路详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
# js
# 选择题测评系统
# 选择题
# Angularjs 实现移动端在线测评效果(推荐)
# 的是
# 表单
# 多选
# 单选
# 又不
# 这叫
# 抛出
# 小编
# 如何处理
# 每题
# 单选题
# 多选题
# 多个
# 不需要
# 给大家
# 可以直接
# 一个小小
# 不正确
# 所述
# 该文件
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
网站制作企业,网站的banner和导航栏是指什么?
小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
公司网站制作价格怎么算,公司办个官网需要多少钱?
laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
Laravel如何为API生成Swagger或OpenAPI文档
Laravel如何实现一对一模型关联?(Eloquent示例)
如何选择PHP开源工具快速搭建网站?
网站制作价目表怎么做,珍爱网婚介费用多少?
php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】
如何快速搭建高效香港服务器网站?
如何在IIS中新建站点并配置端口与IP地址?
EditPlus中的正则表达式 实战(1)
Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
网页设计与网站制作内容,怎样注册网站?
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何在阿里云虚拟主机上快速搭建个人网站?
详解Oracle修改字段类型方法总结
夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化
Bootstrap整体框架之JavaScript插件架构
网站制作软件有哪些,制图软件有哪些?
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
,网页ppt怎么弄成自己的ppt?
Laravel怎么清理缓存_Laravel optimize clear命令详解
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
微信小程序 input输入框控件详解及实例(多种示例)
Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用
javascript如何操作浏览器历史记录_怎样实现无刷新导航
html如何与html链接_实现多个HTML页面互相链接【互相】
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】
java获取注册ip实例
如何快速搭建高效服务器建站系统?
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
Python企业级消息系统教程_KafkaRabbitMQ高并发应用
Laravel观察者模式如何使用_Laravel Model Observer配置
Laravel模型事件有哪些_Laravel Model Event生命周期详解
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐

