源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Javascript实现动态菜单添加的实例代码

  • 时间:2021-12-25 13:46 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Javascript实现动态菜单添加的实例代码
先来看看效果: [img]http://files.jb51.net/file_images/article/201307/201375171638314.jpg[/img] Html源码:
[u]复制代码[/u] 代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="http://www.w3.org/1999/xhtml">  <head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  <title>动态改变菜单</title>  <script type="text/javascript" src="jquery.js"></script>  <script type="text/javascript" src="SelectMenu.js"></script>  </head>  <body>  <form action="#">  <br/>  <br/>  <br/>      <div class="Address">          <span class="Province">Province:              <select>                  <option value="" selected="selected">Please Choose Province</option>                  <option value="HeBei">HeBei</option>                  <option value="ShanDong">ShanDong</option>              </select>           </span>          <span class="City" style="display:none">City:              <select>              </select>          </span>          <span class="Area" style="display:none">Area:              <select>              </select>          </span>          <br/>           <br/>          <span class="AddressSelect" style="display:none">          </span>      </div>  </form>  </body>  </html> 
Javascript源码
[u]复制代码[/u] 代码如下:
$(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("");                     $("<option value=''>Please Choose City</option>").appendTo(CitySelect);                      switch(ProvinceValue)                         {                          //实际项目中,这个城市数组肯定是在服务器获取的,这里为了简便,我就直接自定义了一个数组                           //如果追求完美,这里还可以加一道缓存,防止重复获取                          case "HeBei":                              var CityOfHeBei=["ShiJiaZhuang","CangZhou","LangFang"];                               for(var i=0;i<CityOfHeBei.length;i++){                                  $("<option value='"+CityOfHeBei[i]+"'>"+CityOfHeBei[i]+"</option>").appendTo(CitySelect);                              }                               break;                         case "ShanDong":                              var CityOfShanDon=["JiNan","DeZhou","QingDao"];                                   for(var i=0;i<CityOfShanDon.length;i++){                                  $("<option value='"+CityOfShanDon[i]+"'>"+CityOfShanDon[i]+"</option>").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("");                     $("<option value=''>Please Choose Area</option>").appendTo(AreaSelect);                      switch(CityValue)                         {                         //实际项目中,这个区数组肯定是在服务器获取的,这里为了简便,我就直接自定义了一个数组                          //如果追求完美,这里还可以加一道缓存,防止重复获取                          case "ShiJiaZhuang":                              var AreaOfCity=["GaoXinQu","KaiFaQu","XinHuaQu"];                                 for(var i=0;i<AreaOfCity.length;i++){                                  $("<option value='"+AreaOfCity[i]+"'>"+AreaOfCity[i]+"</option>").appendTo(AreaSelect);                              }                               break;                         case "CangZhou":                              var AreaOfCity=["XinHuaQu","YunHeQu"];                                    for(var i=0;i<AreaOfCity.length;i++){                                  $("<option value='"+AreaOfCity[i]+"'>"+AreaOfCity[i]+"</option>").appendTo(AreaSelect);                              }                              break;                         case "LangFang":                              var AreaOfCity=["AnCiQu","GuangYangQu"];                              for(var i=0;i<AreaOfCity.length;i++){                                  $("<option value='"+AreaOfCity[i]+"'>"+AreaOfCity[i]+"</option>").appendTo(AreaSelect);                              }                              break;                         case "QingDao":                              var AreaOfCity=["GaoXinQu","KaiFaQu","XinHuaQu"];                                 for(var i=0;i<AreaOfCity.length;i++){                                  $("<option value='"+AreaOfCity[i]+"'>"+AreaOfCity[i]+"</option>").appendTo(AreaSelect);                              }                               break;                         case "DeZhou":                              var AreaOfCity=["XinHuaQu","YunHeQu"];                                    for(var i=0;i<AreaOfCity.length;i++){                                  $("<option value='"+AreaOfCity[i]+"'>"+AreaOfCity[i]+"</option>").appendTo(AreaSelect);                              }                              break;                         case "JiNan":                              var AreaOfCity=["AnCiQu","GuangYangQu"];                              for(var i=0;i<AreaOfCity.length;i++){                                  $("<option value='"+AreaOfCity[i]+"'>"+AreaOfCity[i]+"</option>").appendTo(AreaSelect);                              }                              break;                         }                       AreaSelect.parent().show();                } else {                       AreaSelect.parent().hide();              }      });      AreaSelect.change(function(){              var AreaValue=$(this).val();              AddressSelect.html("");              if (AreaValue!=""){                  $("<span>The Address Is --Province: "+ProvinceSelect.val()+"  City: "+CitySelect.val()+"  Area: "+AreaSelect.val()+"</span>").appendTo(AddressSelect);              AddressSelect.show();              //alert("The Address Is  Province: "+ProvinceSelect.val()+"  City: "+CitySelect.val()+"  Area: "+AreaSelect.val());                   }                         })  }); 
这里还引用了Jquery,貌似实现这个效果,用不用都无所谓,最近为了熟悉Jquery的用法,所以就加上了。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部