自动补齐flexselect+级联下拉框案例
2024-08-30 09:54:06
在开发web应用时,经常遇到类似省市区级联下拉框操作,即选中省份自动级联加载该省份所有的市,选中市自动级联加载该市所有的区;假设省市区的数据量很大,此时用户想选中某市,因而要从上往下查找,可能半天都找不到,用户体验不佳,因此引入jQuery插件–自动补齐flexselect可解决该弊端,因为该插件支持模糊检索自动补齐,可在极短时间内找到想要的结果,节省了时间又增强了用户操作速度。
自动补齐flexselect插件用法请看:http://www.tieguanyin168.com/index.php/jqueryflexselect-1505.html
以下模拟省市区级联案例,效果如下:
源码:
1、服务器端代码
public void queryCity() {
String grade=this.getParameter("grade");
List<City> models = cityService.searchCitiesByPid(Integer.valueOf(grade));
if(models!=null&&models.size()>0){
//{"code":200,"data":[{"acronym":"LCQ","areaCode":"","fullName":"福建省泉州市鲤城区","grade":3,"id":1463,"isDel":0,"name":"鲤城区","pid":162,"sellQuantity":0,"signQuantity":0,"zipCode":""},
// {"acronym":"NAS","areaCode":"","fullName":"福建省泉州市南安市","grade":3,"id":1474,"isDel":0,"name":"南安市","pid":162,"sellQuantity":0,"signQuantity":0,"zipCode":""}],
// "success":true}
Utils.returnJson(models);
}
}
2、jsp代码
<div class="bg_row_out">
<div class="bg_row_out_1"> <font color="red">*</font>省:</div>
<div class="bg_row_out_2 required" style="border-right: 0 none;border-bottom: 0px solid #cccccc;">
<!--从服务器获取-->
<select id="provice" name="company.provice" class="newsletter_input">
<option value=""></option>
<c:forEach items="${provinces}" var="provice">
<option value="${provice.id }">${provice.name }</option>
</c:forEach>
</select>
</div>
</div>
<div class="bg_row_out">
<div class="bg_row_out_1"> <font color="red">*</font>市:</div>
<div class="bg_row_out_2 required" style="border-right: 0 none;border-bottom: 0px solid #cccccc;">
<select id="city" name="company.city" class="newsletter_input">
<option value=""></option>
</select>
</div>
</div>
<div class="bg_row_out">
<div class="bg_row_out_1"> <font color="red">*</font>区:</div>
<div class="bg_row_out_2 required" style="border-right: 0 none;border-bottom: 0px solid #cccccc;">
<select id="district" name="company.district" class="newsletter_input">
<option value=""></option>
</select>
</div>
</div>
3、js代码
$(function(){
var district = $("#district").flexselect();
$("#provice").flexselect({callback:function(){
$.ajax( {
url : "queryCity.htm",
data : {
"date" : new Date().getTime(),
"grade" : $("#provice").val()
},
dataType:"json",
success : function(result) {
if(result.code != 200){
alert(result.data);
return;
}
result = result.data;
var resultStr = [];
for ( var i = 0; i < result.length; i++) {
resultStr.push({name:result[i].name, value:result[i].id});
}
city.flexselect[0].cache = resultStr;
}
})
}
});
var city=$("#city").flexselect({callback:function(){
$.ajax( {
url : "queryCity.htm",
data : {
"date" : new Date().getTime(),
"grade" : $("#city").val()
},
dataType:"json",
success : function(result) {
if(result.code != 200){
alert(result.data);
return;
}
result = result.data;
var resultStr = [];
for ( var i = 0; i < result.length; i++) {
resultStr.push({name:result[i].name, value:result[i].id});
}
district.flexselect[0].cache = resultStr;
}
})
}
});
});
最新文章
- Spring-配置bean的方法(工厂方法和Factorybean)【转】
- entityframework使用oracle的几个小问题
- curl文件上传有两种方式,一种是post_fileds,一种是infile
- sudo 权限问题
- WCF、Web API、WCF REST、Web Service之区别
- javascript活动
- Jena 简介:通过 Jena Semantic Web Framework 在 Jave 应用程序中使用 RDF 模型
- Windows 10 IoT Serials 5 - 如何为树莓派应用程序添加语音识别与交互功能
- ES中const
- HDU 1014 Uniform Generator 欧几里得
- Chapter 3 Protecting the Data(2):分配列级权限
- 轻量级原生 ajax 函数,支持 get/array post/array post/json
- Linux:Day17(下) openssl
- HTML相关内容
- django-微信小程序登录
- win2016 配置IIS 和mysql5.7 迁移数据表的两个小坑
- linux安装redis-4.0.2
- 如何安装/卸载workflow manager 1.0
- python 全栈开发,Day135(爬虫系列之第2章-BS和Xpath模块)
- BZOJ1999或洛谷1099&;BZOJ2282或洛谷2491 树网的核&;[SDOI2011]消防