[原创]用Ajax实现动态级联菜单的一段Javascrpit脚本
[watermark]- <script language="javascript">
- var XMLHttpReq;
- var currentSort;
- //创建XMLHttpRequest对象
- function createXMLHttpRequest() {
- if(window.ActiveXObject) {
- //IE 浏览器
- XMLHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
- }
- else if (window.XMLHttpRequest) {
- // Mozilla浏览器
- XMLHttpReq = new XMLHttpRequest();
- }
- //发送请求函数
- function sendRequest(url) {
- createXMLHttpRequest();
- XMLHttpReq.open("GET", url, true);
- XMLHttpReq.onreadystatechange = processResponse;//指定响应函数
- XMLHttpReq.send(null); // 发送请求
- }
- // 处理返回信息函数
- function processResponse() {
- if (XMLHttpReq.readyState == 4) { // 判断对象状态
- if (XMLHttpReq.status == 200) { // 信息已经成功返回,开始处理信息
- updateMenu();
- }
- else { //页面不正常
- alert("您所请求的页面有异常。");
- }
- }
- }
- //更新菜单函数
- function updateMenu() {
- var res=XMLHttpReq.responseXML.getElementsByTagName("res")
- var subMenu = "";
- for(var i = 0; i < res.length; i++) {
- subMenu = subMenu + " " + res[i].firstChild.data + "<br>";
- }
- currentSort.innerHTML = subMenu;
- }
- // 创建级联菜单函数
- function showSubMenu(obj) {
- currentSort =document.getElementById(obj);
- currentSort.parentNode.style.display = "";
- sendRequest("menu?sort=" + obj);
- }
- </script>
复制代码 [/watermark] |