Spring MVC中Ajax实现二级联动的简单实例

时间:2021-05-26

今天写项目遇到了二级联动,期间遇到点问题,写个博客记录一下。

后台Controller:

@RequestMapping("/faultType")@ResponseBodypublic Map<String,Object> faultType(int id,HttpServletRequest request)throws IOException{String ReturnMessage = "";//获取所有子类故障类型List<FaultType> fauList=faultTypeService.getById(id);if(fauList.size()>0){request.setAttribute("childType", fauList);ReturnMessage = "OK";}else {ReturnMessage = "未找到信息";}//*************************************************************Map<String,Object> ReturnMAP = new HashMap<String,Object>();ReturnMAP.put("childType", fauList);return ReturnMAP;}

前台JSP:

<div class="col-sm-3"><div class="form-group"><label class="col-3 control-label no-padding-right">故障类型: </label><select name="faulttype" id="faulttype" onchange="javascript:typeChange()"><c:forEach items="${faultlist }" var="faulist"><option value="${faulist.faultId }">${faulist.faultContent }</option></c:forEach></select></div></div><div class="col-sm-3"><div class="form-group"><label class="col-3 control-label no-padding-right">故障: </label><input id="childTypeCont" name="childTypeCont"value="" type="hidden" class="col-sm-4 form-control" placeholder="故障"><select name="faulttype1" id="faulttype1""><option>--请选择--</option><c:forEach items="${childType }" var="faulist"><option value="${faulist.faultId }">${faulist.faultContent }</option></c:forEach></select></select></div></div>

JS:

function typeChange(){var type=$("#faulttype").val();var html = "<option>--请选择--</option>"; var CommitUrl = "faultType.do?id=" + type;$.ajax( {type : "POST",contentType : "application/json",url : CommitUrl,dataType : 'json',success : function(result){var Curedata = $.extend(true, [], result); if (Curedata.childType != null) { for(var i=0;i<Curedata.childType.length;i++){html+="<option value='"+Curedata.childType[i].faultId+"'>"+Curedata.childType[i].faultContent+"</option>";}$("#faulttype1").empty();$(html).appendTo("#faulttype1") ;} }});}

以下是引用别人写的(原文地址:http://blog.csdn.net/gis__/article/details/6647464)

记性不好的可以收藏下:

1,下拉框:

var cc1 = $(".formcselect[@name='country'] option[@selected]").text();//得到下拉菜单的选中项的文本(注意中间有空格) var cc2 = $('.formcselect[@name="country"]').val(); //得到下拉菜单的选中项的值 var cc3 = $('.formc select[@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的为选中状态.(注意中间没有空格)

3,复选框:

$("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的选择器是强大的.还有很多方法.

<script src="jquery-1.2.1.js"type="text/javascript"></script> <script language="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($("#selectTest option[@selected]").text()); $("#selectTest").attr("value", "2"); }); }); </script> <ahrefahref="#">aaass</a>

<!--下拉框-->

1.<select id="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.var item = $('input[@name=items][@checked]').val();

11.获取select被选中项的文本

12.var item = $("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.var item = $('input[@name=items][@checked]').val();

34.获取select被选中项的文本

35.var item = $("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();//清空下拉框

以上这篇Spring MVC中Ajax实现二级联动的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章