java 动态生成菜单_Javascript实现动态菜单添加

本文介绍了如何使用JavaScript和jQuery实现动态下拉菜单联动效果。当用户在选择省份时,城市下拉菜单会根据选择自动更新,进一步选择城市后,区域下拉菜单也会相应更新。该实现有助于提供更清晰的页面交互,减少用户输入负担。
摘要由CSDN通过智能技术生成

在注册信息的时候,常常需要通过下拉菜单让用户选择,而且希望用户在第一个下拉框做的选择,影响第二个下拉框的内容。有时候,如果第一个下拉框不作出选择,第二个下拉框根本不会页面上显示,为了给用户呈现一个更清晰的页面。

先来看看效果:

0_13264247508n98.gif

Html源码:

动态改变菜单

Province:

Please Choose Province

HeBei

ShanDong

City:

Area:

Javascript源码

$(document).ready(function () {

//找到三个下拉框

var ProvinceSelect = $(".Province").children("select");

var CitySelect = $(".City").children("select");

var AreaSelect = $(".Area").children("select");

var AddressSelect=$(".AddressSelect");

//给第二个下拉框注册事件

ProvinceSelect.change(function () {

//1、获取当前下拉框的值

var ProvinceValue = $(this).val();

//1.1只要第一个下拉框内容有变化,第三个下拉框就要隐藏起来

AreaSelect.parent().hide();

AddressSelect.hide();

AddressSelect.html("");

//2、如果值不为空,则显示城市下拉框

if (ProvinceValue != "") {

CitySelect.html("");

$("Please Choose City").appendTo(CitySelect);

switch(ProvinceValue)

{

//实际项目中,这个城市数组肯定是在服务器获取的,这里为了简便,我就直接自定义了一个数组

//如果追求完美,这里还可以加一道缓存,防止重复获取

case "HeBei":

var CityOfHeBei=["ShiJiaZhuang","CangZhou","LangFang"];

for(var i=0;i

$(""+CityOfHeBei[i]+"").appendTo(CitySelect);

}

break;

case "ShanDong":

var CityOfShanDon=["JiNan","DeZhou","QingDao"];

for(var i=0;i

$(""+CityOfShanDon[i]+"").appendTo(CitySelect);

}

break;

}

CitySelect.parent().show();

} else {

CitySelect.parent().hide();

}

});

//给第二个下拉框注册事件

CitySelect.change(function () {

var CityValue = $(this).val();

AddressSelect.hide();

AreaSelect.parent().hide();

AddressSelect.html("");

if (CityValue != "") {

AreaSelect.html("");

$("Please Choose Area").appendTo(AreaSelect);

switch(CityValue)

{

//实际项目中,这个区数组肯定是在服务器获取的,这里为了简便,我就直接自定义了一个数组

//如果追求完美,这里还可以加一道缓存,防止重复获取

case "ShiJiaZhuang":

var AreaOfCity=["GaoXinQu","KaiFaQu","XinHuaQu"];

for(var i=0;i

$(""+AreaOfCity[i]+"").appendTo(AreaSelect);

}

break;

case "CangZhou":

var AreaOfCity=["XinHuaQu","YunHeQu"];

for(var i=0;i

$(""+AreaOfCity[i]+"").appendTo(AreaSelect);

}

break;

case "LangFang":

var AreaOfCity=["AnCiQu","GuangYangQu"];

for(var i=0;i

$(""+AreaOfCity[i]+"").appendTo(AreaSelect);

}

break;

case "QingDao":

var AreaOfCity=["GaoXinQu","KaiFaQu","XinHuaQu"];

for(var i=0;i

$(""+AreaOfCity[i]+"").appendTo(AreaSelect);

}

break;

case "DeZhou":

var AreaOfCity=["XinHuaQu","YunHeQu"];

for(var i=0;i

$(""+AreaOfCity[i]+"").appendTo(AreaSelect);

}

break;

case "JiNan":

var AreaOfCity=["AnCiQu","GuangYangQu"];

for(var i=0;i

$(""+AreaOfCity[i]+"").appendTo(AreaSelect);

}

break;

}

AreaSelect.parent().show();

} else {

AreaSelect.parent().hide();

}

});

AreaSelect.change(function(){

var AreaValue=$(this).val();

AddressSelect.html("");

if (AreaValue!=""){

$("The Address Is --Province: "+ProvinceSelect.val()+" City: "+CitySelect.val()+" Area: "+AreaSelect.val()+"").appendTo(AddressSelect);

AddressSelect.show();

//alert("The Address Is Province: "+ProvinceSelect.val()+" City: "+CitySelect.val()+" Area: "+AreaSelect.val());

}

})

});

这里还引用了Jquery,貌似实现这个效果,用不用都无所谓,最近为了熟悉Jquery的用法,所以就加上了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值