- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在做一个包含 100 个问题的多项选择测验(它在五个选项卡上显示 20 个问题)。如果人们可以通过页面源代码看到答案,那很好 - 这只是练习。
我目前拥有的是一个 php 数组(目前只有 5 个“测试”问题),它显示带有问题的行、四个单选按钮和一个提交按钮。这个想法是用户阅读问题,选择答案并提交。如果答案正确,则单选按钮显示为绿色。如果错误,单选按钮变为红色,用户重试。
这是我的 PHP 代码的主要部分:
<?php
$set = array();
$set[] = array('q'=>'Question1','qurl'=>'001','ans'=>'zhidao','a'=>'zhidao','b'=>'zhidou','c'=>'zhedao','d'=>'zhedau');
$set[] = array('q'=>'Question2','qurl'=>'002','ans'=>'dajia','a'=>'dazha','b'=>'dajia','c'=>'taqia','d'=>'tazha');
$set[] = array('q'=>'Question3','qurl'=>'003','ans'=>'boduo','a'=>'bodou','b'=>'buoduo','c'=>'boduo','d'=>'buodo');
$set[] = array('q'=>'Question4','qurl'=>'004','ans'=>'wanhuan','a'=>'wanchuan','b'=>'wanhuan','c'=>'wanchun','d'=>'wachuan');
$set[] = array('q'=>'Question5','qurl'=>'005','ans'=>'zhangkou','a'=>'zhongkou','b'=>'zhangko','c'=>'zhangkuo','d'=>'zhangkou');
shuffle($set);
?>
<form>
<table>
<tr class="q0">
<td><td><a class="question" href="#">Question goes here</a></td></td>
<td><input class="radiostyle" type="radio" name="answers" value ="zhidao" /> zhidao</td>
<td><input class="radiostyle" type="radio" name="answers" value ="zhidou" /> zhidou</td>
<td><input class="radiostyle" type="radio" name="answers" value ="zhedao" /> zhedao</td>
<td><input class="radiostyle" type="radio" name="answers" value ="zhedau" /> zhedau</td>
<td><input class="submit submit-0" type="submit" value="Submit" /></td>
</tr>
这是我的 jQuery:
function checkAnswer(set) {
if (set == 2) { /* if this is question set 2 out of the 5 kinds of questions */
$('#questions .submit').click(function(e){
var q = $(this).attr('class').split(' ')[1].split('-')[1];
$('#questions .q'+q+' input').removeClass('radiowrong');
var ans = $("input[@name=answers]:checked").val();
if (ans == jset[q]['ans']) {
$('#questions .q'+q+' .radiostyle').addClass('radioright');
alert('correct!');}
else {
$('#questions .q'+q+' .radiostyle').addClass('radiowrong');}
e.preventDefault();
});
}
}
现在,我并没有经常使用 jQuery,所以请认为我是初学者。如果我的代码看起来效率低下,我深表歉意。我对我的代码有两个主要问题:
首先,我很难让我的 checkAnswer 函数正常工作。我插入了一个警报,看看我的 if 逻辑是否正确,但我没有成功。关于如何让它工作的任何建议?
其次,如何修改我的 jQuery 以便正确更改单选按钮的类?同样,如果用户选择了正确的答案,我希望将单选按钮设为绿色,如果选择错误,则将其设为红色。
(请知道:如果有更简单的方法来向用户显示他们是对还是错,比如更改他们选择的答案的文本颜色,我洗耳恭听。真的任何东西都足够了。 )
如果我需要提供更多信息,请告诉我。
非常感谢。
最佳答案
首先,这是解决方案的一个工作示例 - jsfiddle.net/avrelian/hrnDG/2/ .
以下是您的标记的简化版本。您可能会看到我在这里使用了 label
标签。它对用户更友好,因为用户只需单击标签即可选中单选按钮。此外,label 的样式更简单(例如,在 Mac OS 上)。我使用“正确”和“错误”类来标记适当的答案元素。
<form>
<table>
<tr class="q1">
<td><a class="question" href="#">What is my favorite language?</a></td>
<td>
<input class="radiostyle wrong" type="radio" name="answers" value="Java" id="answers_1_Java" />
<label for="answers_1_Java">Java</label></td>
<td>
<input class="radiostyle right" type="radio" name="answers" value="JavaScript" id="answers_1_JavaScript" />
<label for="answers_1_JavaScript">JavaScript</label></td>
<td>
<input class="radiostyle wrong" type="radio" name="answers" value="Ruby" id="answers_1_Ruby" />
<label for="answers_1_Ruby">Ruby</label></td>
<td>
<input class="radiostyle wrong" type="radio" name="answers" value="C#" id="answers_1_C#" />
<label for="answers_1_C#">C#</label></td>
<td><input class="submit submit-1" type="submit" value="Submit" /></td>
<td></td></tr></table></form>
让我们将表示逻辑提取到 CSS 中。
input.right.checked + label {
color: green;
}
input.wrong.checked + label {
color: red;
}
最后,让我们为 submit
按钮设置一个处理程序。
$('.submit').click(function() {
$(this).closest('tr')
.find('[name="answers"]')
.removeClass('checked')
.filter(':checked')
.addClass('checked');
return false;
});
N.B.:使用 CSS3 :checked
伪类可以更轻松地解决这个问题,因为您不需要提交按钮。请看例子 - jsfiddle.net/avrelian/hrnDG .
input.right:checked + label {
color: green;
}
input.wrong:checked + label {
color: red;
}
关于php - 使用 jQuery 检查单选按钮的值并更改 CSS 类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11706520/
我有一个名为 main.css 的 css 文件和另一个名为 style.css 的文件。我怎样才能在 main.css 中做到这一点? .someClass { //apply rules to
在更新我的 css 之前,我在 Login.css 中有以下内容: body { background-image: url('./pictures/fond.png'); bac
我的 share point 2013 核心 css 和我的 css 之间存在 css 冲突。所以我想把我所有的类都放在 div #s4-workspace 下但是我搜索了一种方法来将所有类分组到这个
我知道您可以覆盖 jsp 页面从 jsp 包含 CSS 文件(即全局 CSS 文件)继承的 CSS 属性。 但是,如果元素中的某个属性弄乱了特定页面,而我不想只使用内联 CSS 在该页面中使用它怎么办
我刚刚发现了 initial-scale 元属性。 以前,我一直在使用 default.css 来定义我所有的样式和大小(用于字体和元素),以便它们在桌面计算机的屏幕上显示得很好。然后,如果您使用的是
我正在尝试使用 LESS CSS 来编写我的 CSS。我已经按顺序导入了 style.less 和 less.js 文件。 现在我想提取 LESS 生成的 CSS。有什么办法可以做到吗?我不想使用脚本
我想知道是否有任何一种软件可以读取大量内联样式中的 HTML 文档并将所有这些样式转换为外部 css 文件。如果只有一页,我可以手动完成。但是有100页。有人有想法吗? 最佳答案 就像有人说的那样,“
当我想从 Styled Components 迁移到 CSS Modules 时,出现了以下问题。 假设我有以下样式组件,它接受动态参数 offset和一个动态 CSS 字符串 theme : con
有没有办法将 CSS 类定义为与另一个类相等?例如,如果我有一个类: .myClass{ background-color: blue; } 有没有一种方法可以将第二个类定义为与 myClas
我正在尝试制作一组按钮,这些按钮贴在页面底部并且由固定的空间隔开。我正在使用 angularJS 的 ng-repeat 指令通过 ajax 请求获取数据,然后我用它来显示按钮。 我的问题在于让按
浏览器是否在加载 CSS 文件时解析 CSS?还是在整个 CSS 文件被浏览器下载后才进行解析?不同浏览器的做法有区别吗?我在哪里可以找到这种底层信息? 这个问题不是 Load and executi
这个问题在这里已经有了答案: Can a CSS class inherit one or more other classes? (29 个答案) 关闭 3 年前。 标题有点乱,我给大家看一下。假
我遇到了最奇怪的问题...... 在最简单的形式中,我有一个包含以下内容的 index.html 文件: (在尝试确定根本原因的过程中,我已经大大减少了它) 当我查看页面的源代码时,我得到以下信息:
我正在使用 Mindscape Workbench 来最小化我的 scss 文件。我的页面设置为使用 *.min.css 文件。在随机时间,min 文件不会与系统的其余部分一起发布。 我有很多 css
请告诉我 CSS 框架和 CSS 网格之间的区别。 最佳答案 CSS 框架也可以是 CSS 网格框架。 CSS 网格框架用于构建 CSS 布局。有一些框架除了构建布局还有其他用途,例如 Hartija
我有无法从页面中删除或更改的 original.css 文件。原始.css table { border-collapse: collapse; border-spacing: 0;
我以前使用 bootstrap css import 很好。 但是我正在尝试使用 CSS 模块,所以我添加了几行。 { test: /\.css$/, use:
有没有办法在 css 选择器中创建一个 css 组。 例如: .SectionHeader { include: .foo; include: .bar; include: .
今天我学习了 CSS 中的两个概念,一个是 CSS 定位(静态、相对、绝对、固定),另一个是 CSS Margin,它定义了元素之间的空间。 假设我想移动一个元素,这是最好的方法吗?因为这两个概念似乎
var paths = { css: './public/apps/user/**/*.css' } var dest = { css: './public/apps/user/css/' } /
我是一名优秀的程序员,十分优秀!