Spring MVC中Ajax实现二级联动的简单实例
今天写项目遇到了二级联动,期间遇到点问题,写个博客记录一下。
后台Controller:
@RequestMapping("/faultType") @ResponseBody publicMap<String,Object>faultType(intid,HttpServletRequestrequest)throwsIOException { StringReturnMessage=""; //获取所有子类故障类型 List<FaultType>fauList=faultTypeService.getById(id); if(fauList.size()>0){ request.setAttribute("childType",fauList); ReturnMessage="OK"; }else{ ReturnMessage="未找到信息"; } //************************************************************* Map<String,Object>ReturnMAP=newHashMap<String,Object>(); ReturnMAP.put("childType",fauList); returnReturnMAP; }
前台JSP:
<divclass="col-sm-3"> <divclass="form-group"> <labelclass="col-3control-labelno-padding-right"> 故障类型:</label> <selectname="faulttype"id="faulttype"onchange="javascript:typeChange()"> <c:forEachitems="${faultlist}"var="faulist"> <optionvalue="${faulist.faultId}">${faulist.faultContent}</option> </c:forEach> </select> </div> </div> <divclass="col-sm-3"> <divclass="form-group"> <labelclass="col-3control-labelno-padding-right"> 故障:</label> <inputid="childTypeCont"name="childTypeCont" value=""type="hidden"class="col-sm-4form-control"placeholder="故障"> <selectname="faulttype1"id="faulttype1""> <option>--请选择--</option> <c:forEachitems="${childType}"var="faulist"> <optionvalue="${faulist.faultId}">${faulist.faultContent}</option> </c:forEach> </select> </select> </div> </div>
JS:
functiontypeChange(){ vartype=$("#faulttype").val(); varhtml="<option>--请选择--</option>"; varCommitUrl="faultType.do?id="+type; $.ajax({ type:"POST", contentType:"application/json", url:CommitUrl, dataType:'json', success:function(result){ varCuredata=$.extend(true,[],result); if(Curedata.childType!=null){ for(vari=0;i<Curedata.childType.length;i++){ html+="<optionvalue='"+Curedata.childType[i].faultId+"'>"+Curedata.childType[i].faultContent+"</option>"; } $("#faulttype1").empty(); $(html).appendTo("#faulttype1"); }} }); }
以下是引用别人写的(原文地址:http://blog.csdn.net/gis__/article/details/6647464)
记性不好的可以收藏下:
1,下拉框:
varcc1=$(".formcselect[@name='country']option[@selected]").text();//得到下拉菜单的选中项的文本(注意中间有空格) varcc2=$('.formcselect[@name="country"]').val();//得到下拉菜单的选中项的值 varcc3=$('.formcselect[@name="country"]').attr("id");//得到下拉菜单的选中项的ID属性值 $("#select").empty();//清空下拉框//$("#select").html(''); $("<optionvalueoptionvalue='1'>1111</option>").appendTo("#select")//添加下拉框的option
稍微解释一下:
1.select[@name='country']option[@selected]表示具有name属性,
并且该属性值为'country'的select元素里面的具有selected属性的option元素;
可以看出有@开头的就表示后面跟的是属性。
2,单选框:
$("input[@type=radio][@checked]").val();//得到单选框的选中项的值(注意中间没有空格) $("input[@type=radio][@value=2]").attr("checked",'checked');//设置单选框value=2的为选中状态.(注意中间没有空格)
$("input[@type=checkbox][@checked]").val();//得到复选框的选中的第一项的值 $("input[@type=checkbox][@checked]").each(function(){//由于复选框一般选中的是多个,所以可以循环输出 alert($(this).val()); }); $("#chk1").attr("checked",'');//不打勾 $("#chk2").attr("checked",true);//打勾 if($("#chk1").attr('checked')==undefined){}//判断是否已经打勾
当然jquery的选择器是强大的. 还有很多方法.
<scriptsrc="jquery-1.2.1.js"type="text/javascript"></script> <scriptlanguage="javascript"type="text/javascript"> $(document).ready(function(){ $("#selectTest").change(function() { //alert("Hello"); //alert($("#selectTest").attr("name")); //$("a").attr("href","xx.html"); //window.location.href="xx.html"; //alert($("#selectTest").val()); alert($("#selectTestoption[@selected]").text()); $("#selectTest").attr("value","2"); }); }); </script> <ahrefahref="#">aaass</a>
<!--下拉框-->
1.<selectid="selectTest"name="selectTest">
2.<optionvalueoptionvalue="1">11</option>
3.<optionvalueoptionvalue="2">22</option>
4.<optionvalueoptionvalue="3">33</option>
5.<optionvalueoptionvalue="4">44</option>
6.<optionvalueoptionvalue="5">55</option>
7.<optionvalueoptionvalue="6">66</option>
8.</select>
9.jqueryradio取值,checkbox取值,select取值,radio选中,checkbox选中,select选中,及其相关获取一组radio被选中项的值
10.varitem=$('input[@name=items][@checked]').val();
11.获取select被选中项的文本
12.varitem=$("select[@name=items]option[@selected]").text();
13.select下拉框的第二个元素为当前选中值
14.$('#select_id')[0].selectedIndex=1;
15.radio单选组的第二个元素为当前选中值
16.$('input[@name=items]').get(1).checked=true;
17.获取值:
18.文本框,文本区域:$("#txt").attr("value");
19.多选框checkbox:$("#checkbox_id").attr("value");
20.单选组radio:$("input[@type=radio][@checked]").val();
21.下拉框select:$('#sel').val();
22.控制表单元素:
23.文本框,文本区域:$("#txt").attr("value",'');//清空内容
24. $("#txt").attr("value",'11');//填充内容
25.多选框checkbox:$("#chk1").attr("checked",'');//不打勾
26. $("#chk2").attr("checked",true);//打勾
27. if($("#chk1").attr('checked')==undefined)//判断是否已经打勾
28.单选组radio:$("input[@type=radio]").attr("checked",'2');//设置value=2的项目为当前选中项
29.下拉框select:$("#sel").attr("value",'-sel3');//设置value=-sel3的项目为当前选中项
30. $("<optionvalueoptionvalue='1'>1111</option><optionvalueoptionvalue='2'>2222</option>").appendTo("#sel")//添
加下拉框的option
31. $("#sel").empty();//清空下拉框
32.获取一组radio被选中项的值
33.varitem=$('input[@name=items][@checked]').val();
34.获取select被选中项的文本
35.varitem=$("select[@name=items]option[@selected]").text();
36.select下拉框的第二个元素为当前选中值
37.$('#select_id')[0].selectedIndex=1;
38.radio单选组的第二个元素为当前选中值
39.$('input[@name=items]').get(1).checked=true;
40.获取值:
41.文本框,文本区域:$("#txt").attr("value");
42.多选框checkbox:$("#checkbox_id").attr("value");
43.单选组radio:$("input[@type=radio][@checked]").val();
44.下拉框select:$('#sel').val();
45.控制表单元素:
46.文本框,文本区域:$("#txt").attr("value",'');//清空内容
47.$("#txt").attr("value",'11');//填充内容
48.多选框checkbox:$("#chk1").attr("checked",'');//不打勾
49.$("#chk2").attr("checked",true);//打勾
50.if($("#chk1").attr('checked')==undefined)//判断是否已经打勾
51.单选组radio:$("input[@type=radio]").attr("checked",'2');//设置value=2的项目为当前选中项
52.下拉框select:$("#sel").attr("value",'-sel3');//设置value=-sel3的项目为当前选中项
53.$("<optionvalueoptionvalue='1'>1111</option><optionvalueoptionvalue='2'>2222</option>").appendTo("#sel")//添加下拉框的option
54.$("#sel").empty();//清空下拉框
以上这篇SpringMVC中Ajax实现二级联动的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。