前几天做级联下拉框,网上搜索了一下,挺多的,静态的居多,动态的也有,但遗憾的是没有找到我需要的。后来我自己写了一个脚本,实现了从数据库中取出数据,形成动态的下拉框, 可以是无限级(因为实现方法是把页面的下拉框名称当作参数传递,因为同一页面相同名称的控件是不存在的,因此可以实现),当然这些可能无意义,现在就看三级下拉框。无刷新,是因为页面加载时把数据全部加载到了页面中;实现动态级联,是因为下级菜单与上级有某种关联(这是肯定的)。下面就说说其具体实现。
脚本部分
<script type="text/javascript">
<!--
//初始化一级下拉框,iSelect为要初始化级联下拉框的组数,如果只有一组,则为1
function init(iSelect)
{
var i;
var j;
for(i=0;i<iSelect;i=i+1)
{
//selectName为二维数组,其中selectName[i][0]存放的是要初始化的一级下拉框的名字
with(eval("this.document.forms[0]."+selectName[i][0]))
{
for(j=0;j<eval(selectName[i][0]+".length");j=j+2)
{
var oOption = document.createElement("OPTION");
oOption.value=eval(selectName[i][0]+"[j]");
oOption.text=eval(selectName[i][0]+"[j+1]");
options.add(oOption);
}
}
}
}
//动态关联各级下拉框,boxName下拉框的名字,num下拉框的级别,
//比如国家,省,城市三级,则与省对应 trendsSelect(ProvinceName,2)
function trendsSelect(boxName,num)
{
var i;
var length;
var j;
var arrTemp;
//selectName[i][num-1]存放的是“i”组菜单的“num”级下拉框的名字
for(i=0;i<selectName.length;i=i+1)
{
//确定为第几组下拉框
if(boxName==selectName[i][num-1])
{
with(eval("this.document.forms[0]."+selectName[i][num-1]))
{
arrTemp=options[options.selectedIndex].value;
}
if(num<selectName[i].length)
{
with(eval("document.forms[0]."+selectName[i][num]))
{
length=0;
//首先给下一级下拉框赋初始值
var oOption = document.createElement("OPTION");
oOption.value="-1";
oOption.text="请选择";
options.add(oOption);
for(j=0;j<eval(selectName[i][num]+".length");j=j+3)
{
if(arrTemp==eval(selectName[i][num]+"[j+2]"))
{
var oOption = document.createElement("OPTION");
oOption.value=eval(selectName[i][num]+"[j]");
oOption.text=eval(selectName[i][num]+"[j+1]");
options.add(oOption);
}
}
}
}
var boxName=selectName[i][num];
//递归调用
trendsSelect(boxName,num+1);
}
}
}
//响应FORM中onreset事件;
function rt(iSelect)
{
var i;
for(i=0;i<iSelect;i=i+1)
{
for(j=1;j<selectName[i].length;j=j+1)
{
with(eval("document.forms[0]."+Sel[i][j]))
{
length=0;
var oOption = document.createElement("OPTION");
oOption.value="-1";
oOption.text="请选择";
options.add(oOption);
}
}
}
}
//判断必选下拉框是否已经选择,如不需要可以不调用,isNull[i]存放的是下拉框的名字
function isNullWithBox()
{
var i;
for(i=0;i<isNull.length;i=i+1)
{
var boxTemp = eval("document.forms[0]." + isNull[i]).value;
if(boxTemp=="-1")
{
alert("此下拉框必选");
eval("document.forms[0]." + isNull[i]).focus();
return false;
}
}
return true;
}
//-->
</script>
引用脚本页面的部分代码
<script type="text/javascript">
<!--
//selectName为二维数组,其中存放的是要各级下拉框的名字
//第一组级联下拉框selectName[0],第二组级联下拉框selectName[1]
var selectName=new Array();
selectName[0]=new Array("CountryID","ProvinceID","CityID");
//必选下拉框数组,如果“ProvinceID”,也为必选,
//则var isNull=new Array("CountryID","ProvinceID");
var isNull=new Array("CountryID");
//定义存放数据库中各级下拉框中的内容的数组
var CountryID=new Array();
var ProvinceID=new Array();
var CityID=new Array();
//-->
</script>
<%
//数据库传值,也可以是结果集,根据实际情况使用
ArrayList alCountry=(ArrayList)request.getAttribute("lCountry");
ArrayList alProvince=(ArrayList)request.getAttribute("lProvince");
ArrayList alCity=(ArrayList)request.getAttribute("lCity");
for(int i=0;i<alCountry.size();i++)
{
//这里作者使用数据表对象
TCountry tCountry=(TCountry)alCountry.get(i);
int j=2*i;//间隔为2
%>
<SCRIPT LANGUAGE="JavaScript">
//2的倍数存放ID,是下拉框的VALUE值,同时供下一级下拉框使用
CountryID[<%=j%>]=["<%=tCountry.getCountryid()%>"];
CountryID[<%=j+1%>]=["<%=tCountry.getCountryname()%>"];
</SCRIPT>
<%}
for(int i=0;i<alProvince.size();i++)
{
TProvince tProvince=(TProvince)alProvince.get(i);
int j=3*i;//间隔为3
%>
<SCRIPT LANGUAGE="JavaScript">
//3的倍数存放ID,是下拉框的VALUE值,同时供下一级下拉框使用
//3的倍数+2 存放上一级ID,供下拉框匹配上一级使用
ProvinceID[<%=j%>]=["<%=tProvince.getProvinceid()%>"];
ProvinceID[<%=j+1%>]=["<%=tProvince.getProvincename()%>"];
ProvinceID[<%=j+2%>]=["<%=tProvince.getParentid()%>"];
</SCRIPT>
<%}
for(int i=0;i<alCity.size();i++)
{
TCity tCity=(TCity)alCity.get(i);
int j=3*i;//间隔为3
%>
<SCRIPT LANGUAGE="JavaScript">
//3的倍数存放ID,是下拉框的VALUE值,同时供下一级下拉框使用
//3的倍数+2 存放上一级ID,供下拉框匹配上一级使用
CityID[<%=j%>]=["<%=tCity.getCityid()%>"];
CityID[<%=j+1%>]=["<%=tCity.getCityname()%>"];
CityID[<%=j+2%>]=["<%=tCity.getProvinceid()%>"];
</SCRIPT>
<%}%>
<tr>
<TD align="right">请选择所在地区</TD>
<TD>
<SELECT name="CountryID" onchange="trendsSelect('CountryID',1)" >
<OPTION value="-1">请选择</OPTION>
</SELECT>
<SELECT name="ProvinceID" onchange="trendsSelect('ProvinceID',2)">
<OPTION value="-1">请选择</OPTION>
</SELECT>
<SELECT name="CityID">
<OPTION value="-1">请选择</OPTION>
</SELECT>
</TD>
</tr>
<SCRIPT LANGUAGE="JavaScript">
<!--
//初始化一级下拉框,其中参数为要初始化级联下拉框的组数,如果有两组,则为2
init(1);
//-->
</SCRIPT>
就说这么多,希望对你有用,也希望提出你的意见。
from:http://blog.csdn.net/opossum/archive/2006/09/21/1261460.aspx
分享到:
相关推荐
ajax实现可配置无刷新级联下拉框...
ASP.Net中的局部刷新,在[removed]中写C#代码,省市地区的局部刷新级联下拉框
用jquery实现级联下拉框效果 源代码+讲解
Android城市级联下拉框(自定义Spinner) 博客地址:http://blog.csdn.net/u012814441/article/details/49073457
AJAX级联下拉框源码 AJAX级联下拉框源码 AJAX级联下拉框源码
asp读取access数据库数据,在html页面动态生成多级级联的下拉框,摆脱静态级联下拉框数据变更烦恼。
内部为四级的级联下拉框,分别为省份,市,县及区和镇及街道四级下拉框;(适用任何语言的纯HTML)详细截图可访问:https://blog.csdn.net/weixin_43972758/article/details/86510419 进行查询。
简单实用的可编辑下拉框,且带有级联效果!操作便捷,调用代码精炼!
使用jquery写的级联下拉框,使用jquery写的级联下拉框
使用JQuery实现漂亮的三级级联下拉框,
JQuery实战第五讲:级联下拉框效果,如果用在《MVC中更加合适
js+xml生成级联下拉框代码.docx
仿美团网团购搜索级联下拉框DEMO,可以进行多级选择!
基于C#的窗体级联下拉框应用实例,级联的下拉框,当你选择下拉框1的时候,下拉框2的值才会变,其实没什么难度,放上来或许对一些C#打基础的朋友有点帮助,在你选择了两个下拉框的后,所取得的值会显示在下边的文本...
级联下拉框页面控件学习,jsp中常用到,三级下拉框,如,国家、省、市例子
基于eclipse开发的Struts+hibernate+SqlServer2000级联下拉框
JQuery可编辑表格、横向纵向菜单、标签页、级联下拉框、窗口
使用ajax和servlet实现两级下拉框的动态级联
无刷新的级联菜单,一级级选,Jquery,Ajax,无刷新加载数据!
select级联下拉列表 JS实多级联动下拉菜单类,简单实现省市区联动菜单! 无刷新级联下拉框的jquery代码 jQuery+HTML5实现的带链接箭头的多级下拉菜单