JS二级级联下拉菜单

有一个二级级联下拉菜单,但是就是不显示,大侠们看看啥问题?
[code="java"]


学院:

-请选择学院-
<%
List list = new ArrayList();
DepartmentDao dao = new DepartmentDaoImpl();
list = dao.findAllDepartments();// 调用实现类的查询全部方法
for (int i = 0; i < list.size(); i++) {
Department d = list.get(i);
%>
http://dl2.iteye.com/upload/attachment/0088/0780/799f640b-7264-396a-b2e1-89ef1b7c3cd1.png[/img]

[/img]

3个回答

你的代码有问题 listMajor[<%=count%>]= new Array(<%=m.getName()%>,<%=m.getM_id()%>,<%=m.getDepartment().getD_id()%>);//把list数据放入listMajor数组

应该改为
listMajor.push([<%=m.getName()%>,<%=m.getM_id()%>,<%=m.getDepartment().getD_id()%>]);
就是加入到数组里面,而你却是又新建数组,就是你代码没有问题,但是你new数组太多了,性能也是有问题的。所以下面代码也是有问题的
unction populateMajor(dID){//显示二级菜单Major

document.getElementById("major").options.length=0;

            if(dID!=""){  
                var dID=parseInt(dID);  

                for(var i=0;i<onecount;i++)  
                    {  
                    if(listMajor[i][2]==dID)  
                        {  

                        document.getElementById("major").options[i]=new Option[listMajor[i][0],listMajor[i][1]];  
                        }  
                    }  
                     }  
            } 

你可以修改为

function populateMajor(dID){

var fragment = document.createDocumentFragment();
for(var i =0;i<listMajor.length;i++){
if(listMajor[i][2] == dID)
var option = document.createElement("option");
option.value = listMajor[i][1];
option.innerHTML = listMajor[i][0];
fragment.appendChild(option);
}
document.getElementById('major').appendChild(fragment);
}
应该没什么大问题的。

muyexia521
木叶下521 太感谢您啦!一天啦,纠结啊!就这一个小错误!今天七夕!祝您有情人终成眷属!
大约 7 年之前 回复
jinandmei
jinbingchuan listMajor.push([<%=m.getName()%>,<%=m.getM_id()%>,<%=m.getDepartment().getD_id()%>]); 改为 listMajor.push(['<%=m.getName()%>',<%=m.getM_id()%>,<%=m.getDepartment().getD_id()%>]); 然后确保m.getName都是有值
大约 7 年之前 回复
muyexia521
木叶下521 奥!你说的是你帮我提到的代码,恩!谢谢啦!我按照你的改啦。但在fireBug看到的listmajor[]里显示的是[undefined, undefined, undefined, 2 更多...],这是啥意思啊?我的listMajor定义是: for (int i = 0; i < list1.size(); i++) { MajorAndClass m = list1.get(i); %> listMajor.push([<%=m.getName()%>,<%=m.getM_id()%>,<%=m.getDepartment().getD_id()%>]); <% } %>
大约 7 年之前 回复
jinandmei
jinbingchuan 就是if后面少了{}
大约 7 年之前 回复
jinandmei
jinbingchuan if(listMajor[i][2] == dID) var option = document.createElement("option"); option.value = listMajor[i][1]; option.innerHTML = listMajor[i][0]; fragment.appendChild(option); 应该变为 if(listMajor[i][2] == dID) { var option = document.createElement("option"); option.value = listMajor[i][1]; option.innerHTML = listMajor[i][0]; fragment.appendChild(option); }
大约 7 年之前 回复
jinandmei
jinbingchuan if(listMajor[i][2] == dID) { var option = document.createElement("option"); option.value = listMajor[i][1]; option.innerHTML = listMajor[i][0]; fragment.appendChild(option); 应该为 if(listMajor[i][2] == dID) var option = document.createElement("option"); option.value = listMajor[i][1]; option.innerHTML = listMajor[i][0]; fragment.appendChild(option); }
大约 7 年之前 回复
muyexia521
木叶下521 少了?没啊!您说清楚点啊
大约 7 年之前 回复
jinandmei
jinbingchuan if 上面少了一个 { }
大约 7 年之前 回复
muyexia521
木叶下521 恩!有的!用firBug可以看到里边的数据。
大约 7 年之前 回复
jinandmei
jinbingchuan 你首先看下listMajor这个数组里面有值吗
大约 7 年之前 回复
jinandmei
jinbingchuan 我是说没有什么大的问题,不一定就是全部没问题,listMajor数组里面有值吗?你debug看信息了吗?因为没有你的源码,所以只能大致写的
大约 7 年之前 回复
muyexia521
木叶下521 按照你说的改啦,可惜没变化!
大约 7 年之前 回复

建议楼主用JQUERY写,又省事又快。~

var listMajor = new Array();
listMajor.push(['111_1',3,1]);
listMajor.push(['111_2',4,1]);
listMajor.push(['111_3',5,1]);
listMajor.push(['222_1',6,2]);
listMajor.push(['222_2',7,2]);

function populateMajor(dID){
document.getElementById('major').innerHTML ='';
var fragment = document.createDocumentFragment();
for(var i =0;i<listMajor.length;i++){
if(listMajor[i][2] == dID) {
var option = document.createElement("option");
option.value = listMajor[i][1];
option.innerHTML = listMajor[i][0];
fragment.appendChild(option);
}
}

document.getElementById('major').appendChild(fragment); 
} 


111
222




select

muyexia521
木叶下521 按照你说的做!<% for (int i = 0; i < list1.size(); i++) { MajorAndClass m = list1.get(i); %> listMajor.push([<%=m.getName()%>,<%=m.getM_id()%>,<%=m.getDepartment().getD_id()%>]); <% } %> 在firBug里看到listMajor是空,但数据已经查出来啦,为什么放不进去呢?
大约 7 年之前 回复
立即提问
相关内容推荐