Ajax+Json 级联菜单实现代码
作者:bea
第一个下拉框: 代码如下: <select id="select" name="rawfoodBasic.category" onchange="doChange(this.value);"> //第一个下拉框里的值 </select> 第二个下拉框: 代码如下: <select id="subSelect" name="rawfoodBasic.absorb" onchange="javascript:alert(this.
第一个下拉框:
代码如下:
<select id="select" name="rawfoodBasic.category" onchange="doChange(this.value);">
//第一个下拉框里的值
</select>
第二个下拉框:
代码如下:
<select id="subSelect" name="rawfoodBasic.absorb" onchange="javascript:alert(this.value);" > //要3及菜单还可以在次写相应的时间
<option value="0">--请选择二级菜单-- </option>
</select>
js代码:
代码如下:
<script type="text/javascript">
$.ajaxSetup({
cache:false
}); //清除ajax中之前的值
function doChange(obj){
var url = '<c:url value="/nutrition/getSubDictDataToJsonByCategory.action"/>'+"?rawfood.category="+obj;//第一个下拉框选中后进入的action,action中给第二个下拉框所需的值赋值
$.getJSON(url,function(json){
var seleOjb=document.getElementById("subSelect");
for(var k=0;k<seleOjb.options.length;k++){
seleOjb.options.remove(k); //当再选中第一个下拉框中的值时,把第二个下拉框中原来的值清除
}
$.each(json.subCategoryDictList,function(index,subDictData){
var optionj=document.createElement("option"); //为第二个下拉框赋值
optionj.value = subDictData.id;
//alert(subDictData.id);
optionj.text=subDictData.name;
seleOjb.add(optionj);
});
});
}
</script>
代码如下:
<action name="getSubDictDataToJsonByCategory" class="rawfoodAction" method="getSubDictDataToJsonByCategory">
<result name="success" type="json">
<param name="includeProperties"> //定义返回的参数
^subCategoryDictList[d+].id,
^subCategoryDictList[d+].name
</param>
</result>
</action>
有用 | 无用
代码如下:
<select id="select" name="rawfoodBasic.category" onchange="doChange(this.value);">
//第一个下拉框里的值
</select>
第二个下拉框:
代码如下:
<select id="subSelect" name="rawfoodBasic.absorb" onchange="javascript:alert(this.value);" > //要3及菜单还可以在次写相应的时间
<option value="0">--请选择二级菜单-- </option>
</select>
js代码:
代码如下:
<script type="text/javascript">
$.ajaxSetup({
cache:false
}); //清除ajax中之前的值
function doChange(obj){
var url = '<c:url value="/nutrition/getSubDictDataToJsonByCategory.action"/>'+"?rawfood.category="+obj;//第一个下拉框选中后进入的action,action中给第二个下拉框所需的值赋值
$.getJSON(url,function(json){
var seleOjb=document.getElementById("subSelect");
for(var k=0;k<seleOjb.options.length;k++){
seleOjb.options.remove(k); //当再选中第一个下拉框中的值时,把第二个下拉框中原来的值清除
}
$.each(json.subCategoryDictList,function(index,subDictData){
var optionj=document.createElement("option"); //为第二个下拉框赋值
optionj.value = subDictData.id;
//alert(subDictData.id);
optionj.text=subDictData.name;
seleOjb.add(optionj);
});
});
}
</script>
代码如下:
<action name="getSubDictDataToJsonByCategory" class="rawfoodAction" method="getSubDictDataToJsonByCategory">
<result name="success" type="json">
<param name="includeProperties"> //定义返回的参数
^subCategoryDictList[d+].id,
^subCategoryDictList[d+].name
</param>
</result>
</action>
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- javascript 面向对象,实现namespace,class,继承,重载
- javascript实现的距离现在多长时间后的一个格式化的日期
- jQuery 判断元素上是否绑定了事件
- Firebug 字幕文件JSON地址获取代码
- jquery 选择器部分整理
- JavaScript 全角转半角部分
- js apply/call/caller/callee/bind使用方法与区别分析
- javascript 时间比较实现代码
- 浅谈javascript 面向对象编程
- 小议javascript 设计模式 推荐
- JavaScript 组件之旅(四):测试 JavaScript 组件
- JavaScript 组件之旅(三):用 Ant 构建组件
- JavaScript 组件之旅(二)编码实现和算法
- JavaScript 组件之旅(一)分析和设计
- js 数组实现一个类似ruby的迭代器
- jquery 操作单选框,复选框,下拉列表实现代码
- javascript获得CheckBoxList选中的数量
- 基于jQuery的日期选择控件
- javascript 读取XML数据,在页面中展现、编辑、保存的实现