我想用javascript做一个级联select。描述如下。项目用的框架是struts1+hibernate+spring。谢谢! 10

前一个select选择的是学校的院系,后一个select根据前面选择的院系到数据库中查找该院系下的专业并将该专业显示在select框中。院系和专业都是从数据库出来的。效果... 前一个select选择的是学校的院系,后一个select根据前面选择的院系到数据库中查找该院系下的专业并将该专业显示在select框中。院系和专业都是从数据库出来的。效果图大概就是下面这样的。可以使用jQuery框架或纯js代码。谢谢 展开
 我来答
历盆郁7
2012-05-02 · TA获得超过4277个赞
知道大有可为答主
回答量:1795
采纳率:100%
帮助的人:940万
展开全部
给你的小例子吧,为了方便,数据是在js里面定义的.

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML>
<HEAD>
<TITLE>级联</TITLE>
</HEAD>
<script type="text/javascript" src="../jquery-1.7.js"></script>
<BODY>
<script type="text/javascript">

// 院系,格式:院系ID + 院系名称
var yuanxi = ['1_信息工程学院','2_外语学院'];

// 专业,格式:专业ID + 专业名称 + 院系ID
var zhuanye = ['1_计算机科学与技术_1','2_自动化_1','3_英语系_2','4_日语系_2','5_法语系_2'];

$(function(){
$('#yuanxiSelect').initSelect().change(function(){$('#zhuanyeSelect').changeSelect();});
$('#zhuanyeSelect').changeSelect();
});

$.fn.initSelect = function(){
for(var i = 0; i < yuanxi.length; i++){
var arr = yuanxi[i].split('_');
$(this).append("<option value='" + arr[0]+ "'>" + arr[1]+ "</options>");
}

return this;
}

$.fn.changeSelect = function(){

$(this).empty();

var yuanxiVal = $('#yuanxiSelect').val();

for(var i = 0; i < zhuanye.length; i++){
var arr = zhuanye[i].split('_');
if(arr[2] == yuanxiVal){
$(this).append("<option value='" + arr[0]+ "'>" + arr[1]+ "</options>");
}
}

return this;
}
</script>

院系:<select id="yuanxiSelect" ></select>
专业:<select id="zhuanyeSelect" ></select>
</BODY>
</HTML>
追问
您好!感谢你的关注!您给的例子很好,我看懂了。但是如果数据来源于数据库,比如在我的Action方法里有一语句request.setAttribute("yuanxi",yuanxiList);将从数据库中获取的院系列表yuanxiList放置在request中,请问在jsp页面的javascript中怎么访问这些数据呢?
追答
有两种以上实现方式,下面只举两个例子.这东西等你熟练了,可以按照自己的想法去做,

1,动态利用ajax获取"专业"列表数据
2.在action中手动拼写javascript脚本.查出所有的"院系","专业"数据,拼接成符合特定格式的数据(格式可参考我给的)
部分代码如下:
StringBuffer buf = new StringBuffer();
buf.append('');
buf.append("var yuanxi = ['1_信息工程学院','2_外语学院'];")
.....
request.setAttribute("script",buf.toString());

jsp页面上:
${script},生成的源代码,就如我上面的例子了.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
阳光天使54321
2012-05-02
知道答主
回答量:5
采纳率:0%
帮助的人:2.5万
展开全部
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<script language="javascript">
<!--
var where = new Array(36);
function comefrom(loca,locashi) { this.loca = loca; this.locashi = locashi; }
where[0]= new comefrom("请选择省份!","请选择相应的城市!");
where[1] = new comefrom("北京","|东城|西城|崇文|宣武|朝阳|丰台|石景山|海淀|门头沟|房山|通州|顺义|昌平|大兴|平谷|怀柔|密云|延庆");
where[2] = new comefrom("上海","|黄浦|卢湾|徐汇|长宁|静安|普陀|闸北|虹口|杨浦|闵行|宝山|嘉定|浦东|金山|松江|青浦|南汇|奉贤|崇明");
where[3] = new comefrom("天津","|和平|东丽|河东|西青|河西|津南|南开|北辰|河北|武清|红挢|塘沽|汉沽|大港|宁河|静海|宝坻|蓟县");
where[4] = new comefrom("重庆","|万州|涪陵|渝中|大渡口|江北|沙坪坝|九龙坡|南岸|北碚|万盛|双挢|渝北|巴南|黔江|长寿|綦江|潼南|铜梁|大足|荣昌|壁山|梁平|城口|丰都|垫江|武隆|忠县|开县|云阳|奉节|巫山|巫溪|石柱|秀山|酉阳|彭水|江津|合川|永川|南川");
where[5] = new comefrom("河北","|石家庄|邯郸|邢台|保定|张家口|承德|廊坊|唐山|秦皇岛|沧州|衡水");
where[6] = new comefrom("山西","|太原|大同|阳泉|长治|晋城|朔州|吕梁|忻州|晋中|临汾|运城");
where[7] = new comefrom("内蒙古","|呼和浩特|包头|乌海|赤峰|呼伦贝尔盟|阿拉善盟|哲里木盟|兴安盟|乌兰察布盟|锡林郭勒盟|巴彦淖尔盟|伊克昭盟");
where[8] = new comefrom("辽宁","|沈阳|大连|鞍山|抚顺|本溪|丹东|锦州|营口|阜新|辽阳|盘锦|铁岭|朝阳|葫芦岛");
where[9] = new comefrom("吉林","|长春|吉林|四平|辽源|通化|白山|松原|白城|延边");
where[10] = new comefrom("黑龙江","|哈尔滨|齐齐哈尔|牡丹江|佳木斯|大庆|绥化|鹤岗|鸡西|黑河|双鸭山|伊春|七台河|大兴安岭");
where[11] = new comefrom("江苏","|南京|镇江|苏州|南通|扬州|盐城|徐州|连云港|常州|无锡|宿迁|泰州|淮安|丹徒|丹阳|张家港|太仓|昆山|吴江|海门|如皋|如东|扬中|东台|溧阳|武进|江阴|锡山|宜兴|金坛");
where[12] = new comefrom("浙江","|杭州|宁波|温州|嘉兴|湖州|绍兴|金华|衢州|舟山|台州|丽水");
where[13] = new comefrom("安徽","|合肥|芜湖|蚌埠|马鞍山|淮北|铜陵|安庆|黄山|滁州|宿州|池州|淮南|巢湖|阜阳|六安|宣城|亳州");
where[14] = new comefrom("福建","|福州|厦门|莆田|三明|泉州|漳州|南平|龙岩|宁德");
where[15] = new comefrom("江西","|南昌市|景德镇|九江|鹰潭|萍乡|新馀|赣州|吉安|宜春|抚州|上饶");
where[16] = new comefrom("山东","|济南|青岛|淄博|枣庄|东营|烟台|潍坊|济宁|泰安|威海|日照|莱芜|临沂|德州|聊城|滨州|菏泽");
where[17] = new comefrom("河南","|郑州|开封|洛阳|平顶山|安阳|鹤壁|新乡|焦作|濮阳|许昌|漯河|三门峡|南阳|商丘|信阳|周口|驻马店|济源");
where[18] = new comefrom("湖北","|武汉|宜昌|荆州|襄樊|黄石|荆门|黄冈|十堰|恩施|潜江|天门|仙桃|随州|咸宁|孝感|鄂州");
where[19] = new comefrom("湖南","|长沙|常德|株洲|湘潭|衡阳|岳阳|邵阳|益阳|娄底|怀化|郴州|永州|湘西|张家界");
where[20] = new comefrom("广东","|广州|深圳|珠海|汕头|东莞|中山|佛山|韶关|江门|湛江|茂名|肇庆|惠州|梅州|汕尾|河源|阳江|清远|潮州|揭阳|云浮");
where[21] = new comefrom("广西","|南宁|柳州|桂林|梧州|北海|防城港|钦州|贵港|玉林|南宁地区|柳州地区|贺州|百色|河池");
where[22] = new comefrom("海南","|海口|三亚");
where[23] = new comefrom("四川","|成都|绵阳|德阳|自贡|攀枝花|广元|内江|乐山|南充|宜宾|广安|达川|雅安|眉山|甘孜|凉山|泸州");
where[24] = new comefrom("贵州","|贵阳|六盘水|遵义|安顺|铜仁|黔西南|毕节|黔东南|黔南");
where[25] = new comefrom("云南","|昆明|大理|曲靖|玉溪|昭通|楚雄|红河|文山|思茅|西双版纳|保山|德宏|丽江|怒江|迪庆|临沧");
where[26] = new comefrom("西藏","|拉萨|日喀则|山南|林芝|昌都|阿里|那曲");
where[27] = new comefrom("陕西","|西安|宝鸡|咸阳|铜川|渭南|延安|榆林|汉中|安康|商洛");
where[28] = new comefrom("甘肃","|兰州|嘉峪关|金昌|白银|天水|酒泉|张掖|武威|定西|陇南|平凉|庆阳|临夏|甘南");
where[29] = new comefrom("宁夏","|银川|石嘴山|吴忠|固原");
where[30] = new comefrom("青海","|西宁|海东|海南|海北|黄南|玉树|果洛|海西");
where[31] = new comefrom("新疆","|乌鲁木齐|石河子|克拉玛依|伊犁|巴音郭勒|昌吉|克孜勒苏柯尔克孜|博尔塔拉|吐鲁番|哈密|喀什|和田|阿克苏");
where[32] = new comefrom("香港","香港");
where[33] = new comefrom("澳门","澳门");
where[34] = new comefrom("台湾","|台北|高雄|台中|台南|屏东|南投|云林|新竹|彰化|苗栗|嘉义|花莲|桃园|宜兰|基隆|台东|金门|马祖|澎湖");
where[35] = new comefrom("其他","其他");
function select() {
with(document.user_reg.sheng) { var loca2 = options[selectedIndex].value; }
for(i = 0;i < where.length;i ++) {
if (where[i].loca == loca2) {
loca3 = (where[i].locashi).split("|");
for(j = 0;j < loca3.length;j++) { with(document.user_reg.shi) { length = loca3.length;
options[j].text = loca3[j]; options[j].value = loca3[j]; var
loca4=options[selectedIndex].value;}}
break;
}}
document.user_reg.address.value=loca2+loca4;
}
function init() {
with(document.user_reg.sheng) {
length = where.length;
for(k=0;k<where.length;k++) { options[k].text = where[k].loca; options[k].value =
where[k].loca; }
options[selectedIndex].text = where[0].loca; options[selectedIndex].value = where[0].loca;
}
with(document.user_reg.shi) {
loca3 = (where[0].locashi).split("|");
length = loca3.length;
for(l=0;l<length;l++) { options[l].text = loca3[l]; options[l].value = loca3[l]; }
options[selectedIndex].text = loca3[0]; options[selectedIndex].value = loca3[0];
}}
-->
</script>
</head>
<BODY onload='init();'>
<form id="user_reg" name="user_reg" method="post" action="">
<input name="address" type="text" value=""/>
<select name="sheng" onchange="select()">
</select>
<select name="shi" onChange="select()"></select>
</form>
</body>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jiajiaxinyi521
2012-05-03
知道答主
回答量:14
采纳率:0%
帮助的人:5万
展开全部
用ajax可以实现,效果更好一下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式