密保互斥问题:

密保通常都会有n个问题,让用户选择其中2、3个,而且都不会让用户选择重复的问题。这就要求密保互斥。

效果如下:

下面我用了jquery实现密保互斥,用于解决密保,投票等类似互斥问题,可以支持ie6+,火狐,谷歌,opera等大多数浏览器

demo下载:http://download.csdn.net/download/cwqcwk1/5956141

关键代码:

<script type="text/javascript">
var qObj = {
elmt:'select',
tip:'请选择',
tVal:'',
cur:[],
arr:{
1:'你的小学叫什么名字?',
2:'你最崇拜的人物是谁?',
3:'你最喜欢的花名字叫什么?',
4:'你父亲的职业是?',
5:'你父亲的姓名?',
6:'你高中班主任的名字?'
}
} $(function(){
//获取所有的select选框
var elements = $(qObj.elmt); //这一步只是初始化操作,将所有问题写入select选框
elements.each(function(i){
var html = '<option value="'+ qObj.tVal +'">'+ qObj.tip +'</option>';
for(var q in qObj.arr){
html += '<option value="'+ q +'">' + qObj.arr[q] + '</option>';
}
$(this).html(html);
}); //select选框添加监听事件
elements.change(function(){
var
cValue = {}, //用于记录当前被选中的问题
elmts = elements,
cIndex = elmts.index($(this)); //当前select选框索引值 //遍历所有select选框,记录当前每个选框的选择
elmts.each(function(i){
qObj.cur[i] = $(this).val();
}); //记录当前已被选中的问题,实现互斥锁
for(var i in qObj.cur){
cValue[qObj.cur[i]] = 1;
} //遍历所有select选框,重置所有问题
elmts.each(function(i){
//跳过当前的select选框,因为该内容无需校正
if (cIndex == i) return;
var html = '<option value="'+ qObj.tVal +'">'+ qObj.tip +'</option>';
for(var q in qObj.arr){
//如果是互斥内容,且不属于这个选框则跳过(重点)
if (cValue[q] && q != qObj.cur[i]) continue;
html += '<option value="'+ q +'"' + (q == qObj.cur[i]?' selected="selected"': '') + '>' + qObj.arr[q] + '</option>';
}
$(this).html(html);
});
}); })
</script>
密保1:<select style="width:180px"></select><br/>
密保2:<select style="width:180px"></select><br/>
密保3:<select style="width:180px"></select>

最新文章

  1. PHP 进程详解
  2. POJ 1273 Drainage Ditches题解——S.B.S.
  3. Java集合类学习笔记(各种线性表性能分析)
  4. mac系统下Ruby环境安装
  5. hdu 2036 - 改革春风吹满地(计算几何)
  6. JQuery解析json数据
  7. [iOS-UI]点击清空按钮,却会有提交的感觉
  8. BZOJ-1013 球形空间产生器sphere 高斯消元+数论推公式
  9. Java主流日志工具库
  10. 一个简单的Dump转文本工具—Dump2Text
  11. Javascript Date类常用方法详解
  12. OWASP
  13. Python时间和日期学习
  14. PHP生成订单号(产品号+年的后2位+月+日+订单号)
  15. C#中单问号,双问号的用法(转)
  16. 基于TCP/IP协议的C++网络编程(API函数版)
  17. FFmpeg的Android平台移植—编译篇
  18. mysql进阶(二)索引简易教程
  19. Codeforces Round #483 (Div. 2)
  20. 【EF】CodeFirst Fluent API使用记录

热门文章

  1. C# Double类型 不四舍五入
  2. [转] iOS开发- UICollectionView详解+实例
  3. PHP MySQL 预处理语句
  4. C++普通函数与模板函数以及特化函数重载的优先级问题
  5. jquery 导航栏目
  6. Automatically watermark all uploaded photos (给所有上传的相片加水印)
  7. Python自动化运维之21、CSS
  8. 解决easyui-tab添加tab滚动条问题
  9. linux crontab 计划任务 atd和windows下的计划任务
  10. 「Poetize10」能量获取