急啊~~~~~ 请教联动菜单的问题(有数据库) zen me xie a?xiexie 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 在数据库里有老师和学生的对应表单吧~选择了老师以后,可以参照下段代码编写,用的是JAVASCRIPT </tr> <tr class="style2"> <td><div align="left" class="style2">所属部门:</div></td> <td><div align="center" class="style2"> <select name="admin_department"> <option value="市场部">市场部</option> <option value="技术部">技术部</option> <option value="财务部">财务部</option><script language="javascript">for(i=0;i<=form1.admin_department.options.length-1;i++){ if (form1.admin_department.options[i].value=="<%=department%>") { form1.admin_department.options[i].selected=true; break; }}</script> </select> </div></td> </tr> 可以利用XMLHTTP实现无刷新取值JS:function GetData(strURL){ var xmlHttp=null; var strData=""; try { xmlHttp=new ActiveXObject("Microsoft.XMLHTTP"); //xmlHttp.open("POST",strURL,false); xmlHttp.open("GET",strURL,false); xmlHttp.send(); strData=xmlHttp.responseText;//接受服务器输出的字符串. } catch(e) { window.confirm(e); } xmlHttp=null; return strData;}服务器strURL=*.jsp的内容<% try { stmt=conn.createStatement(); rs=stmt.executeQuery("select * from tablename"); while(rs.next()) { strData=strData+rs.getString(5)+","+rs.getString(6)+"#"; } rs.close(); stmt.close(); conn.close(); } catch(Exception e) {System.out.println(e);} if(strData.length()>1) { out.println(strData.substring(0,strData.length()-1)); }%>大概就这个意思. 有个ASP的例子比较完整http://www.cnsxml.com/blogview.asp?logID=316利用XMLHTTP实现的二级连动Select利用XMLHTTP实现的二级连动Select.这是继 "利用XMLHTTP无刷新获取数据" 的另一篇关于XMLHTTP的应用.关于XMLHTTP.可以说,是一个很好的接合剂.把客户端和服务端的距离拉近了.利用XMLHTTP.我们可以实现很多好的想法.这文章.实现了二级连动Select.传统二级连动是把所有的数据都传到有客户端..利用XMLHTTP.我们可以实时地返回我们所需要的数据.select.htm程序代码: <script language="JavaScript">function GetResult(str){/* *--------------- GetResult(str) ----------------- * GetResult(str) * 功能:通过XMLHTTP发送请求,返回结果. * 参数:str,字符串,发送条件. * 实例:GetResult(document.all.userid.value); * author:wanghr100(灰豆宝宝.net) * update:2004-5-27 19:02 *--------------- GetResult(str) ----------------- */ var oBao = new ActiveXObject("Microsoft.XMLHTTP"); oBao.open("POST","Server.asp?sel="+str,false); oBao.send(); //服务器端处理返回的是经过escape编码的字符串. //通过XMLHTTP返回数据,开始构建Select. BuildSel(unescape(oBao.responseText),document.all.sel2)}function BuildSel(str,sel){/* *--------------- BuildSel(str,sel) ----------------- * BuildSel(str,sel) * 功能:通过str构建Select. * 参数:str,字符串,由服务端返回的.有特定结构"字符串1,字符串2,字符串3" * 参数:sel,要构建的Select * 实例:BuildSel(unescape(oBao.responseText),document.all.sel2) * author:wanghr100(灰豆宝宝.net) * update:2004-5-27 19:02 *--------------- BuildSel(str,sel) ----------------- */ //先清空原来的数据. sel.options.length=0; var arrstr = new Array(); arrstr = str.split(","); //开始构建新的Select. for(var i=0;i<arrstr.length;i++) { sel.options[sel.options.length]=new Option(arrstr[i],arrstr[i]) }}</script><select name="sel" onChange="GetResult(this.value)"><option value="">请选择<option value="福建省">福建省<option value="湖北省">湖北省<option value="辽宁省">辽宁省<select><select name="sel2"></select> server.asp 服务器端处理.程序代码: <% @Language="JavaScript" %><%function OpenDB(sdbname){/* *--------------- OpenDB(sdbname) ----------------- * OpenDB(sdbname) * 功能:打开数据库sdbname,返回conn对象. * 参数:sdbname,字符串,数据库名称. * 实例:var conn = OpenDB("database.mdb"); * author:wanghr100(灰豆宝宝.net) * update:2004-5-12 8:18 *--------------- OpenDB(sdbname) ----------------- */ var connstr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="+Server.MapPath(sdbname); var conn = Server.CreateObject("ADODB.Connection"); conn.Open(connstr); return conn;}var oConn = OpenDB("data.mdb");var province = Request("sel");var arrResult = new Array();var sql = "select city from china where province='"+province+"'";var rs = Server.CreateObject("ADODB.Recordset");rs.Open(sql,oConn,1,1);while(!rs.EOF){ //遍历所有适合的数据放入arrResult数组中. arrResult[arrResult.length] = rs("city").Value; rs.MoveNext();}//escape解决了XMLHTTP。中文处理的问题.//数组组合成字符串.由","字符串连接.Response.Write(escape(arrResult.join(",")));%> 数据库设计data.mdb表china.字段id 自动编号province 文本city 文本表:china 数据: id province city1 福建省 福州市2 福建省 厦门市3 福建省 泉州市4 湖北省 武汉市5 湖北省 荆州市6 湖北省 宜昌市7 辽宁省 沈阳市8 辽宁省 大连市9 辽宁省 盘锦市 如果有完整的JSP代码可以打包发给大家呀,我的邮箱[email protected],我最近也在找,谢谢 这个其实很简单,你先将这两个表的数据都取出来,分别存在javascript的ArrayList中,注意:索引要一一对应。之后就可以在点生产厂家的列表时(在它的点击事件中作处理),根据它在ArrayList中的索引值取出相应产品列表中的索引值就行了,这样子做速度会更快的。 http://community.csdn.net/Expert/topic/3392/3392536.xml?temp=.2350428 在初始化时把表中数据都都读出来新建个哈希表和向量,key放Teacher的主键,value中放一个vector把与Key中老师相对应的所有学生的主键全部加到vector中然后在列表上加一个事件监听点了哪个老师,查哈西表找到老师相对应的vector然后把vector中的值加到列表中就行了只要读一遍数据库速度很快 struts2文件下载问题 web项目运行一段时间后就白屏 web开发,学习javascirpt选择用那本书好 求助!jsp如何 通过radio取text的值 有没有字符串数组逆向拷贝方法啊? JSP动态树型菜单如何刷新 有谁可以做医院门诊查询系统的设计与开发这个项目,计算机本科毕业论文,急!!!!!!!! 怎样解决mysql数据库操作中出现的乱码问题? 各路高手,请问怎样通过jsp用程序代码来连接不同的MDB数据库, 一个下拉表联动的奇怪问题 电子地图的实现 请大家帮忙!看看这个问题!
选择了老师以后,可以参照下段代码编写,用的是JAVASCRIPT
</tr>
<tr class="style2">
<td><div align="left" class="style2">所属部门:</div></td>
<td><div align="center" class="style2">
<select name="admin_department">
<option value="市场部">市场部</option>
<option value="技术部">技术部</option>
<option value="财务部">财务部</option>
<script language="javascript">
for(i=0;i<=form1.admin_department.options.length-1;i++)
{
if (form1.admin_department.options[i].value=="<%=department%>")
{
form1.admin_department.options[i].selected=true;
break;
}
}
</script>
</select>
</div></td>
</tr>
JS:
function GetData(strURL)
{
var xmlHttp=null;
var strData="";
try
{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
//xmlHttp.open("POST",strURL,false);
xmlHttp.open("GET",strURL,false);
xmlHttp.send();
strData=xmlHttp.responseText;//接受服务器输出的字符串.
}
catch(e)
{
window.confirm(e);
}
xmlHttp=null;
return strData;
}服务器strURL=*.jsp的内容
<%
try
{
stmt=conn.createStatement();
rs=stmt.executeQuery("select * from tablename");
while(rs.next())
{
strData=strData+rs.getString(5)+","+rs.getString(6)+"#";
}
rs.close();
stmt.close();
conn.close();
}
catch(Exception e)
{System.out.println(e);}
if(strData.length()>1)
{
out.println(strData.substring(0,strData.length()-1));
}
%>
大概就这个意思.
http://www.cnsxml.com/blogview.asp?logID=316
利用XMLHTTP实现的二级连动Select
利用XMLHTTP实现的二级连动Select.这是继 "利用XMLHTTP无刷新获取数据" 的另一篇关于XMLHTTP的应用.
关于XMLHTTP.可以说,是一个很好的接合剂.把客户端和服务端的距离拉近了.
利用XMLHTTP.我们可以实现很多好的想法.这文章.实现了二级连动Select.
传统二级连动是把所有的数据都传到有客户端..
利用XMLHTTP.我们可以实时地返回我们所需要的数据.
select.htm程序代码:
<script language="JavaScript">
function GetResult(str)
{
/*
*--------------- GetResult(str) -----------------
* GetResult(str)
* 功能:通过XMLHTTP发送请求,返回结果.
* 参数:str,字符串,发送条件.
* 实例:GetResult(document.all.userid.value);
* author:wanghr100(灰豆宝宝.net)
* update:2004-5-27 19:02
*--------------- GetResult(str) -----------------
*/
var oBao = new ActiveXObject("Microsoft.XMLHTTP");
oBao.open("POST","Server.asp?sel="+str,false);
oBao.send();
//服务器端处理返回的是经过escape编码的字符串.
//通过XMLHTTP返回数据,开始构建Select.
BuildSel(unescape(oBao.responseText),document.all.sel2)
}function BuildSel(str,sel)
{
/*
*--------------- BuildSel(str,sel) -----------------
* BuildSel(str,sel)
* 功能:通过str构建Select.
* 参数:str,字符串,由服务端返回的.有特定结构"字符串1,字符串2,字符串3"
* 参数:sel,要构建的Select
* 实例:BuildSel(unescape(oBao.responseText),document.all.sel2)
* author:wanghr100(灰豆宝宝.net)
* update:2004-5-27 19:02
*--------------- BuildSel(str,sel) -----------------
*/
//先清空原来的数据.
sel.options.length=0;
var arrstr = new Array();
arrstr = str.split(",");
//开始构建新的Select.
for(var i=0;i<arrstr.length;i++)
{
sel.options[sel.options.length]=new Option(arrstr[i],arrstr[i])
}
}
</script>
<select name="sel" onChange="GetResult(this.value)">
<option value="">请选择
<option value="福建省">福建省
<option value="湖北省">湖北省
<option value="辽宁省">辽宁省
<select>
<select name="sel2"></select>
server.asp 服务器端处理.
程序代码:
<% @Language="JavaScript" %>
<%
function OpenDB(sdbname)
{
/*
*--------------- OpenDB(sdbname) -----------------
* OpenDB(sdbname)
* 功能:打开数据库sdbname,返回conn对象.
* 参数:sdbname,字符串,数据库名称.
* 实例:var conn = OpenDB("database.mdb");
* author:wanghr100(灰豆宝宝.net)
* update:2004-5-12 8:18
*--------------- OpenDB(sdbname) -----------------
*/
var connstr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="+Server.MapPath(sdbname);
var conn = Server.CreateObject("ADODB.Connection");
conn.Open(connstr);
return conn;
}
var oConn = OpenDB("data.mdb");
var province = Request("sel");
var arrResult = new Array();
var sql = "select city from china where province='"+province+"'";
var rs = Server.CreateObject("ADODB.Recordset");
rs.Open(sql,oConn,1,1);
while(!rs.EOF)
{
//遍历所有适合的数据放入arrResult数组中.
arrResult[arrResult.length] = rs("city").Value;
rs.MoveNext();
}
//escape解决了XMLHTTP。中文处理的问题.
//数组组合成字符串.由","字符串连接.
Response.Write(escape(arrResult.join(",")));
%>
数据库设计
data.mdb
表china.
字段
id 自动编号
province 文本
city 文本表:china 数据:
id province city
1 福建省 福州市
2 福建省 厦门市
3 福建省 泉州市
4 湖北省 武汉市
5 湖北省 荆州市
6 湖北省 宜昌市
7 辽宁省 沈阳市
8 辽宁省 大连市
9 辽宁省 盘锦市
新建个哈希表和向量,
key放Teacher的主键,value中放一个vector
把与Key中老师相对应的所有学生的主键全部加到vector中
然后在列表上加一个事件监听
点了哪个老师,查哈西表找到老师相对应的vector
然后把vector中的值加到列表中就行了
只要读一遍数据库
速度很快