亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

解析Ajax實例教程-----級聯菜單

2024-09-01 08:26:23
字體:
來源:轉載
供稿:網友

關于ajax的特性,這里不再寫了,去網上隨便就能找到好多. 現在寫一個用ajax和jsp來實現的動態菜單的實例.先感覺一下ajax是如何實現傳說中的異步操作!
menu.html
<html>
<head>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<LINK href="images/css.css" type=text/css rel=stylesheet>
<script language="javascript">
var XMLHttpReq;
var currentSort;
//創建XMLHttpRequest對象
function createXMLHttpRequest() {
if(window.XMLHttpRequest) { //Mozilla 瀏覽器
XMLHttpReq = new XMLHttpRequest();
}
else if (window.ActiveXObject) { // IE瀏覽器
try {
XMLHttpReq = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
XMLHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}
}
//發送請求函數
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].lastChild.data;
}
currentSort.innerHTML = subMenu;
}
// 創建級聯菜單函數
function showSubMenu(obj) {
currentSort = document.getElementById(obj);
currentSort.parentNode.style.display = "";
sendRequest("menu.jsp?sort=" + obj);
}

</script>

</head>
<body>
<table style="BORDER-COLLAPSE: collapse" borderColor=#111111
cellSpacing=0 cellPadding=0 width=200 bgColor=#f5efe7 border=0>

<TR>
<TD align=middle bgColor=#dbc2b0 height=19><B>指標操作</B> </TD>
</TR>
<tr>
<td height="20"> <a onClick="showSubMenu('A')">一級指標A</a> </td>
</tr>
<tr style="display:none">
<td height="20" id="A"> </td>
</tr>
<tr>
<td height="20"> <a onClick="showSubMenu('B')">一級指標B</a> </td>
</tr>
<tr style="display:none ">
<td height="20" id="B"> </td>
</tr>
</table>
</body>
</html>

menu.jsp

<%@ page contentType="text/html; charset=GBK" %>
<%
//接收瀏覽器端提交的信息
String sort=request.getParameter("sort");
String contents1="";
String contents2="";
if(sort.equals("A")){
contents1="一級指標AA";
contents2="一級指標AB";
}else if(sort.equals("B")){
contents1="二級指標BA";
contents2="二級指標BB";
}
//傳回響應數據
response.setContentType("text/xml; charset=UTF-8");
response.setHeader("Cache-Control", "no-cache");
out.println("<response>");
out.println("<res>" + contents1 + "</res>");
out.println("<res>" + contents2 + "</res>");
out.println("</response>");
out.close();
%>
OK , 代碼就這么多,十分簡單.
下面簡單介紹一下上面的ajax操作:

<!--[if !supportLists]-->1. <!--[endif]--> ajax技術主要由四部分組成

javascript

css

dom

XMLHttpRequest

<!--[if !supportLists]-->2. <!--[endif]--> ajax的核心對象

XMLHttpRequest

<!--[if !supportLists]-->3. <!--[endif]--> XMLHttpRequest對象的方法

void open(String method, String url, boolean async)

void send(String body)

void setHeader(String header, String value)

String getResponseHeader(String header)

String getAllResponseHeaders()

void abort()

 

<!--[if !supportLists]-->4. <!--[endif]-->XMLHttpRequest對象的屬性

返回值類型
屬性名
Number
readyState
Function
Onreadystatechange
String
responseText
XmlDocument
responseXML
Number
status
String
statusText

<!--[if !supportLists]-->5. <!--[endif]-->ajax 操作的主要步驟

⑴ 聲明一個XMLHttpRequest對象.

⑵ 調用window.open(method, url , boolean),執行后臺操作

⑶ 對返回值進行操作, 一般用XMLHttpRequest對象的onreadystatechange屬性.

⑷ 執行send(body)方法.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品高清在线| 精品少妇一区二区30p| 国产精品高潮粉嫩av| 国产精品久久综合av爱欲tv| 日韩av中文字幕在线免费观看| 久久久久久国产精品久久| 97热在线精品视频在线观看| 亚洲国产成人在线播放| 欧美性生交xxxxxdddd| 亚洲大胆人体av| 成人国产精品久久久久久亚洲| 69**夜色精品国产69乱| 欧美日韩一区免费| 国产日产亚洲精品| 亚洲v日韩v综合v精品v| 亚洲一区二区三区sesese| 国产91精品高潮白浆喷水| 日本亚洲精品在线观看| 亚洲v日韩v综合v精品v| 亚洲一区二区三区777| 国产精品亚洲片夜色在线| 国产精品丝袜白浆摸在线| 国产精品免费久久久| 国产激情999| 福利视频导航一区| 国产精品久久久久久久久借妻| 欧美日韩在线观看视频小说| 久久久久中文字幕| 欧美中文字幕视频在线观看| 亚洲高清不卡av| 欧洲成人在线观看| 欧美主播福利视频| 97成人精品区在线播放| 国产视频精品一区二区三区| 高清欧美性猛交| 人体精品一二三区| 成人在线免费观看视视频| 日韩中文字幕在线播放| 在线观看欧美www| 91亚洲国产精品| 久久综合久久美利坚合众国| 国产精品男女猛烈高潮激情| 久久人人爽人人爽人人片亚洲| 91a在线视频| 亚洲精品免费一区二区三区| 日本午夜人人精品| 午夜精品一区二区三区在线| 日韩亚洲精品电影| 国产精品成人久久久久| 欧美成人亚洲成人| 欧美成人精品h版在线观看| 亚洲欧美日韩精品久久奇米色影视| 成人黄色免费网站在线观看| 精品成人乱色一区二区| 日韩三级影视基地| 欧美激情综合色综合啪啪五月| 久久久久久久久久久免费| 成人网在线免费观看| 国产精品福利片| 国产精品久久久久久久一区探花| 久久国产精品影片| 国产免费一区二区三区在线观看| 最近2019中文字幕在线高清| 精品女同一区二区三区在线播放| 国产丝袜精品第一页| 福利视频第一区| 日韩黄色高清视频| 在线日韩第一页| 国产一区二区动漫| 亚洲国产小视频在线观看| 欧美成人免费大片| 亚洲男人天天操| 性色av一区二区三区在线观看| 亚洲大胆美女视频| 成人福利免费观看| 欧美极品欧美精品欧美视频| 久久电影一区二区| 中文字幕亚洲欧美一区二区三区| 欧美尺度大的性做爰视频| 日韩精品在线视频| 91日本视频在线| 国产精品成人一区| 成人做爰www免费看视频网站| 91久久久久久| 久久久久久久久久久成人| 日韩成人性视频| 日韩在线视频免费观看高清中文| 亚洲欧美国产日韩中文字幕| 懂色av中文一区二区三区天美| 亚洲a在线观看| 欧美日韩一区二区三区在线免费观看| 日韩视频免费在线| 欧美日韩精品国产| 亚洲理论电影网| 久久久久北条麻妃免费看| 日韩中文字幕国产精品| 激情懂色av一区av二区av| 美女性感视频久久久| 日本精品视频在线观看| 在线播放亚洲激情| 欧美日韩国产中字| 日韩中文在线视频| 97国产在线视频| 精品国产一区二区三区久久狼黑人| 亚洲第一区在线观看| 色婷婷综合成人av| 国产成人福利夜色影视| 亚洲丁香婷深爱综合| 国产综合色香蕉精品| 国产精品三级网站| 欧美成人免费播放| 亚洲欧美日本另类| 国产欧美在线观看| 国内精久久久久久久久久人| 国产欧美一区二区三区在线| 亚洲福利视频网站| www欧美日韩| 久久精品一本久久99精品| 久久久精品久久| 亚洲精品国产精品久久清纯直播| 欧美影院在线播放| 久久久极品av| 久久久av免费| 国产在线视频一区| 一本色道久久88精品综合| 成人午夜两性视频| 亚洲深夜福利在线| 欧美激情一区二区三级高清视频| 国产啪精品视频| 97在线视频精品| 最新亚洲国产精品| 日韩精品免费一线在线观看| 欧美性猛交xxxx乱大交极品| 国产丝袜视频一区| 日韩精品免费在线播放| 久久久这里只有精品视频| 亚洲精品网址在线观看| 国产91网红主播在线观看| 国产精品三级美女白浆呻吟| 亚洲福利视频免费观看| 性色av香蕉一区二区| 亚洲欧美国产制服动漫| 91久久中文字幕| 亚洲色图第三页| 国产精品成人在线| 国产一区二区三区在线观看视频| 久久av红桃一区二区小说| 久久精品亚洲94久久精品| 亚洲最大av网| 日韩免费精品视频| 欧亚精品在线观看| 亚洲国产欧美在线成人app| 欧美与黑人午夜性猛交久久久| 亚洲一区av在线播放| 91精品国产综合久久香蕉最新版| 亚洲成人网在线| 久久久久久亚洲精品不卡| 亚洲视频视频在线| 亚洲综合色激情五月| 亚洲欧美中文日韩在线| 精品欧美激情精品一区| 中文字幕日韩免费视频| 色综合久久中文字幕综合网小说| 欧美日韩激情网|