Spring MVC中Ajax实现二级联动的简单实例
来源: 阅读:2286 次 日期:2016-07-25 16:32:41
温馨提示: 小编为您整理了“Spring MVC中Ajax实现二级联动的简单实例”,方便广大网友查阅!

下面小编就为大家带来一篇Spring MVC中Ajax实现二级联动的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。

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

后台Controller:

@RequestMapping("/faultType")

@ResponseBody

public 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实现二级联动的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map