分享
 
 
 

不刷新当前页面,而多个下拉框联动

王朝java/jsp·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

一、初始化工作:

1.一个封装了数据查询的JavaBean(当前为SqlDispose)

2.数据库的结构(及数据)如下:

id name spec model place

----------- ---------- ---------- ---------- ----------

1 电脑 IBM 台式机 1#

2 电脑 IBM 笔记本 1#

3 电脑 IBM 服务器 1#

4 电脑 联想 台式机 1#

5 电脑 联想 笔记本 1#

6 电脑 联想 服务器 1#

7 电脑 宏基 平板电脑 1#

8 机械 小松 挖掘机 1#

9 电脑 IBM 台式机 2#

当然,如上的数据库结构可以改成一对多关系的多个关(仅需要修改部分内容)。

二、两个关键文件(changeSelect.js,xml.jsp)

//changeSelect.js

/*--得到远程数据--*/

var oReq;

x = new ActiveXObject("Microsoft.XMLDOM");

function getRemoteData(field1,field2,option)

{

var strA = "";

oReq = new ActiveXObject("Microsoft.XMLHTTP");

oReq.open("POST","xml.jsp?field1="+field1+"&field2="+field2+option,false);

oReq.setRequestHeader("Content-Length",strA.length);

oReq.setRequestHeader("Content-type","application/x-www-form-urlencoded");

oReq.send(strA);

}

/*--重画下拉框--*/

function changeSelect(select,source,target,option)

{

getRemoteData(target,option,"&"+source+"="+select.options[select.selectedIndex].value);

clearSelect(eval("form1."+target));

fillSelect(eval("form1."+target));

}

/*--清空下拉框--*/

function clearSelect(select)

{

select.options.length = 0;

select.options[select.options.length]= new Option("--请选择--","");

}

/*--填充下拉框--*/

function fillSelect(select)

{

x.loadXML(oReq.responseText);

n=x.selectNodes("/root/id");

if(n!=null)

{

for(i=0;i<n.length;i++)

{

select.options[select.options.length]=new Option(n(i).text,n(i).text);

}

}

}

//xml.jsp

<%@ page import="java.sql.*"%>

<%@ page contentType="text/html;charset=GBK"%>

<jsp:useBean id="operate" scope="page" class="SqlDispose"/>

<root>

<%

ResultSet rs;

String sql;

String temp;

String field1,field2;

field1 = request.getParameter("field1");

field2 = request.getParameter("field2");

temp = new String(request.getParameter(field2).getBytes("ISO8859-1"),"GBK");

sql = "select "+field1+" from product where "+field2+"='"+temp+"' group by "+field1;

rs = operate.rs(sql);

while(rs.next())

{

out.println("<id>"+rs.getString(1)+"</id>");

}

%>

</root>

三、演示文件(demo.jsp)

<%@ page import="java.sql.*" contentType="text/html;charset=GBK"%>

<jsp:useBean id="operate" scope="page" class="SqlDispose"/>

<head>

<script language="JavaScript" src="changeSelect.js"></script>

</head>

<form name="form1">

<select name="name" onchange="clearSelect(form1.model),clearSelect(form1.place),changeSelect(this,'name','spec','name')">

<option>--请选择--</option>

<%

ResultSet rs;

rs = operate.rs("select name from product group by name");

while(rs.next())

{

out.print("<option value=");

out.print(rs.getString("name")+">");

out.print(rs.getString("name"));

out.println("</option>");

}

%>

</select>

<select name="spec" onchange="clearSelect(form1.place),changeSelect(this,'spec','model','spec')"></select>

<select name="model" onchange=changeSelect(this,"model","place","model")></select>

<select name="place"></select>

</form>

四、最后说明

以上提供了一个不刷新当前页,各个下拉框就可以联动,而且支持无限扩展(相对)。由于是GET方法传值,所以传值字符需要进行处理,

本文是在假定十分正常的条件下运行。由于HTTP的请求资料标识符的长度有限,所以当下拉框的个数受请求资料标识符的长度限制。如果数据

结构改用一对多的关系表,用ID传值,效果会有所好转。

以上部分逻辑如果再进行封装,或者以标签的形式来运行,效果会更好。由于其不涉及到这里的内容,所以未加介绍。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有