首页 > 语言 > JavaScript > 正文

javascript实现dom动态创建省市纵向列表菜单的方法

2024-05-06 16:20:14
字体:
来源:转载
供稿:网友

这篇文章主要介绍了javascript实现dom动态创建省市纵向列表菜单的方法,可实现省市列表菜单效果,涉及javascript鼠标事件及页面处理json数据的技巧,需要的朋友可以参考下

本文实例讲述了javascript实现dom动态创建省市纵向列表菜单的方法。分享给大家供大家参考。具体实现方法如下:

 

 
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  3. <html xmlns="http://www.w3.org/1999/xhtml"
  4. <head> 
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  6. <title>动态创建纵向列表</title> 
  7. <style type="text/css"
  8. a { color: #000; text-decoration: none; } 
  9. a:hover { color: #F00; } 
  10. #menu { width: 100px; border: 1px solid #CCC; border-bottom:none;} 
  11. #menu ul { list-style: none; margin: 0px; padding: 0px; } 
  12. #menu ul li { background: #eee; padding: 0px 8px; height: 26px; line-height: 26px; border-bottom: 1px solid #CCC; position:relative; } 
  13. #menu ul li ul { display:none; position: absolute; left: 100px; top: 0px; width:100px;border:1px solid #ccc; border-bottom:none; } 
  14. #menu ul li.current ul { display:block;}  
  15. #menu ul li ul li{text-align:center;} /*设置城市内容居中*/ 
  16. </style> 
  17. <script type="text/javascript"
  18. var provs = { "江西省": ["南昌市""景德镇""九江""鹰潭""萍乡""新馀""赣州""吉安""宜春""抚州""上饶"], 
  19. "福建省": ["福州""厦门""莆田""三明""泉州""漳州""南平""龙岩""宁德"], 
  20. "河北省": ["石家庄""邯郸""邢台""保定""张家口""承德""廊坊""唐山""秦皇岛""沧州""衡水"], 
  21. "四川省": ["成都市""自贡市""攀枝花市""泸州市""德阳市""绵阳市""广元市""遂宁市""内江市""乐山市""南充市""眉山市""宜宾市""广安市""达州市""雅安市""巴中市""资阳市""阿坝藏族羌族自治州""甘孜藏族自治州""凉山彝族自治州"], 
  22. "山西省": ["太原市""大同市""阳泉市""长治市""晋城市""朔州市""晋中市""运城市""忻州市""临汾市""吕梁市"], 
  23. "内蒙古": ["呼和浩特市""包头市""乌海市""赤峰市""通辽市""鄂尔多斯市""呼伦贝尔市""巴彦淖尔市""乌兰察布市""兴安盟""锡林郭勒盟""阿拉善盟"], 
  24. "海南省": ["海口市""三亚市"], "重庆市": ["重庆"],  
  25. "贵州省": ["贵阳市""六盘水市""遵义市""安顺市""铜仁地区""黔西南布依族苗族自治州""毕节地区""黔东南苗族侗族自治州""黔南布依族苗族自治州"], 
  26. "甘肃省": ["兰州市""嘉峪关市""金昌市""白银市""天水市""武威市""张掖市""平凉市""酒泉市""庆阳市""定西市""陇南市""临夏回族自治州""甘南藏族自治州"], 
  27. "青海省": ["西宁市""海东地区""海北藏族自治州""黄南藏族自治州""海南藏族自治州""果洛藏族自治州""玉树藏族自治州""海西蒙古族藏族自治州"], 
  28. "宁夏自治区": ["银川市""石嘴山市""吴忠市""固原市""中卫市"
  29. }; 
  30. function iniEvent() { 
  31. var provUL = document.getElementById("prov"); 
  32. if (provUL) { 
  33. var allli = provUL.getElementsByTagName("li"); 
  34. for (i = 0; i < allli.length; i++) { 
  35. node = allli[i]; 
  36. node.onmouseover = function () { //鼠标经过时显示层 
  37. this.className = "current"
  38. node.onmouseout = function () { //鼠标离开时隐藏层 
  39. this.className = this.className.replace("current"""); 
  40. function loadData() {  
  41. var provUL = document.getElementById("prov"); 
  42. var nIndex = 0; 
  43. for (var key in provs) { 
  44. var provLi = document.createElement("li"); 
  45. provLi.id = "provLI" + nIndex; 
  46. provLi.innerHTML = "<a href='#'>" + key + "</a>"
  47. provUL.appendChild(provLi); //添加省份li 
  48. //================添加城市======================== 
  49. var citys = provs[key]; 
  50. if (citys.length > 0) { 
  51. var cityUL = document.createElement("ul"); 
  52. var maxLength = 0; //存放最大城市内容的长度,以便后面设置cityUL的最大宽度,达到宽度自适应 
  53. for (var i = 0; i < citys.length; i++) { 
  54. var cityName = citys[i]; 
  55. if (cityName.length > maxLength) { 
  56. maxLength = cityName.length; //提取最大长度的城市 
  57. var cityLI = document.createElement("li"); 
  58. cityLI.id = "cityLI" + i; 
  59. cityLI.innerHTML = "<a href='#'>" + cityName + "</a>"
  60. cityUL.appendChild(cityLI); 
  61. if (maxLength <= 6) { 
  62. maxLength = 100; 
  63. else { 
  64. maxLength = maxLength * 20; 
  65. //这里乘以20主要是按一个字20px来算 
  66. maxLength = maxLength + "px"//加上像素的px后缀 
  67. cityUL.style.width= maxLength; //设置cityUL的最大宽度 
  68. provLi.appendChild(cityUL); //添加城市UL 
  69. nIndex++; 
  70. iniEvent(); //初始化事件 
  71. </script> 
  72. </head> 
  73. <body onload ="loadData()"
  74. <div id="menu"
  75. <ul id="prov"
  76. </ul> 
  77. </div>  
  78. </body> 
  79. </html> 

希望本文所述对大家的javascript程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选