Spring MVC中Ajax實(shí)現(xiàn)二級聯(lián)動的簡單實(shí)例
今天寫項(xiàng)目遇到了二級聯(lián)動,期間遇到點(diǎn)問題,寫個博客記錄一下。
后臺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();//得到下拉菜單的選中項(xiàng)的文本(注意中間有空格)
var cc2 = $('.formcselect[@name="country"]').val(); //得到下拉菜單的選中項(xiàng)的值
var cc3 = $('.formc select[@name="country"]').attr("id");//得到下拉菜單的選中項(xiàng)的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(); //得到單選框的選中項(xiàng)的值(注意中間沒有空格)
$("input[@type=radio][@value=2]").attr("checked",'checked');//設(shè)置單選框value=2的為選中狀態(tài).(注意中間沒有空格)
3,復(fù)選框:
$("input[@type=checkbox][@checked]").val(); //得到復(fù)選框的選中的第一項(xiàng)的值
$("input[@type=checkbox][@checked]").each(function(){//由于復(fù)選框一般選中的是多個,所以可以循環(huán)輸出
alert($(this).val());
});
$("#chk1").attr("checked",'');//不打勾
$("#chk2").attr("checked",true);//打勾
if($("#chk1").attr('checked')==undefined){} //判斷是否已經(jīng)打勾
當(dāng)然jquery的選擇器是強(qiáng)大的. 還有很多方法.
<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選中,及其相關(guān)獲取一組radio被選中項(xiàng)的值
10.var item = $('input[@name=items][@checked]').val();
11.獲取select被選中項(xiàng)的文本
12.var item = $("select[@name=items] option[@selected]").text();
13.select下拉框的第二個元素為當(dāng)前選中值
14.$('#select_id')[0].selectedIndex = 1;
15.radio單選組的第二個元素為當(dāng)前選中值
16.$('input[@name=items]').get(1).checked = true;
17.獲取值:
18.文本框,文本區(qū)域:$("#txt").attr("value");
19.多選框checkbox:$("#checkbox_id").attr("value");
20.單選組radio: $("input[@type=radio][@checked]").val();
21.下拉框select: $('#sel').val();
22.控制表單元素:
23.文本框,文本區(qū)域:$("#txt").attr("value",'');//清空內(nèi)容
24. $("#txt").attr("value",'11');//填充內(nèi)容
25.多選框checkbox: $("#chk1").attr("checked",'');//不打勾
26. $("#chk2").attr("checked",true);//打勾
27. if($("#chk1").attr('checked')==undefined) //判斷是否已經(jīng)打勾
28.單選組radio:$("input[@type=radio]").attr("checked",'2');//設(shè)置value=2的項(xiàng)目為當(dāng)前選中項(xiàng)
29.下拉框select:$("#sel").attr("value",'-sel3');//設(shè)置value=-sel3的項(xiàng)目為當(dāng)前選中項(xiàng)
30. $("<optionvalueoptionvalue='1'>1111</option><optionvalueoptionvalue='2'>2222</option>").appendTo("#sel")//添
加下拉框的option
31. $("#sel").empty();//清空下拉框
32.獲取一組radio被選中項(xiàng)的值
33.var item = $('input[@name=items][@checked]').val();
34.獲取select被選中項(xiàng)的文本
35.var item = $("select[@name=items] option[@selected]").text();
36.select下拉框的第二個元素為當(dāng)前選中值
37.$('#select_id')[0].selectedIndex = 1;
38.radio單選組的第二個元素為當(dāng)前選中值
39.$('input[@name=items]').get(1).checked = true;
40.獲取值:
41.文本框,文本區(qū)域:$("#txt").attr("value");
42.多選框checkbox:$("#checkbox_id").attr("value");
43.單選組radio: $("input[@type=radio][@checked]").val();
44.下拉框select: $('#sel').val();
45.控制表單元素:
46.文本框,文本區(qū)域:$("#txt").attr("value",'');//清空內(nèi)容
47.$("#txt").attr("value",'11');//填充內(nèi)容
48.多選框checkbox: $("#chk1").attr("checked",'');//不打勾
49.$("#chk2").attr("checked",true);//打勾
50.if($("#chk1").attr('checked')==undefined) //判斷是否已經(jīng)打勾
51.單選組radio:$("input[@type=radio]").attr("checked",'2');//設(shè)置value=2的項(xiàng)目為當(dāng)前選中項(xiàng)
52.下拉框select:$("#sel").attr("value",'-sel3');//設(shè)置value=-sel3的項(xiàng)目為當(dāng)前選中項(xiàng)
53.$("<optionvalueoptionvalue='1'>1111</option><optionvalueoptionvalue='2'>2222</option>").appendTo("#sel")//添加下拉框的option
54.$("#sel").empty();//清空下拉框
以上這篇Spring MVC中Ajax實(shí)現(xiàn)二級聯(lián)動的簡單實(shí)例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- spring為java.util.Properties類型的屬性進(jìn)行賦值過程解析
- springboot~ObjectMapper~dto到entity的自動賦值
- Spring Boot使用Value注解給靜態(tài)變量賦值的方法
- Spring boot + thymeleaf 后端直接給onclick函數(shù)賦值的實(shí)現(xiàn)代碼
- Spring boot整合Mybatis實(shí)現(xiàn)級聯(lián)一對多CRUD操作的完整步驟
- Spring Data MongoDB中實(shí)現(xiàn)自定義級聯(lián)的方法詳解
- SpringBoot沒有主清單屬性的解決方法
- Spring Boot中的屬性綁定的實(shí)現(xiàn)
- spring級聯(lián)屬性賦值的兩種方式解析
相關(guān)文章
JQuery實(shí)現(xiàn)動態(tài)表格點(diǎn)擊按鈕表格增加一行
動態(tài)表格,功能為點(diǎn)擊添加按鈕,表格增加一行并給其name屬性賦予的值,點(diǎn)擊刪除,自動刪除這一行,具體實(shí)現(xiàn)如下2014-08-08
把html頁面的部分內(nèi)容保存成新的html文件的jquery代碼
把html頁面的部分內(nèi)容保存成新的html文件,用到了jquery的獲取指定id的內(nèi)容。然后保存代碼。2009-11-11
基于jQuery實(shí)現(xiàn)的雙11天貓拆紅包抽獎效果
這篇文章主要介紹了基于jQuery實(shí)現(xiàn)的雙11天貓拆紅包抽獎效果,在即將到來的雙十二活動中大家也可以使用拆紅包抽獎吸引消費(fèi)者,需要的朋友可以參考下2015-12-12
jQuery 翻牌或百葉窗效果(內(nèi)容三秒自動切換)
jQuery 翻牌或百葉窗效果(內(nèi)容三秒自動切換),讓列表內(nèi)容不再枯燥2012-06-06
jQuery簡單實(shí)現(xiàn)仿京東分類導(dǎo)航層效果
這篇文章主要介紹了jQuery簡單實(shí)現(xiàn)仿京東分類導(dǎo)航層效果,涉及jQuery針對鼠標(biāo)事件的響應(yīng)及頁面元素動態(tài)操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-06-06
跟著JQuery API學(xué)Jquery 之三 篩選
跟著JQuery API學(xué)Jquery 之三 篩選,相當(dāng)于條件判斷類型。2010-04-04
jQuery插件FusionCharts實(shí)現(xiàn)的2D柱狀圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件FusionCharts實(shí)現(xiàn)的2D柱狀圖效果,結(jié)合完整實(shí)例形式分析了FusionCharts插件繪制2D柱狀圖的實(shí)現(xiàn)步驟與相關(guān)屬性設(shè)置技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
修改jQuery Validation里默認(rèn)的驗(yàn)證方法
在最近做的一個項(xiàng)目中,使用jQuery Validation驗(yàn)證日期,遇到的問題和一個沒有預(yù)料到的情況是,在ASP.NET MVC 3的項(xiàng)目中,對于 input type="date" data-val="true"的元素,如果調(diào)用form的valid方法驗(yàn)證form,雖然我沒有添加日期驗(yàn)證的設(shè)置2012-02-02
jQuery+HTML5實(shí)現(xiàn)圖片上傳前預(yù)覽效果
這篇文章主要介紹了jQuery+HTML5實(shí)現(xiàn)圖片上傳前預(yù)覽效果,涉及jquery操作圖片動態(tài)顯示效果,非常簡單實(shí)用,需要的朋友可以參考下2015-08-08

