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

首頁 > 開發 > AJAX > 正文

一日精通Ajax技術

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


  Ajax這個名稱怎么來的,本人也不得而之了,大概是(Active Javascript Action Xml)吧,說白一點就是運用了 javascript、xmlhttp和xmldom技術及網站后臺來處理用戶的一些操作的方法吧。

  那么本人就分三步來說明如何使用 Ajax 技術來做開發。

  一、用 javascript 操作 xmlhttp 對象

  二、服務器部對xmlhttp請求的響應(PHP范例)

  三、xmldom 的使用方法

  先說第一部份:

  一、用 javascript 操作 xmlhttp 對象

  IE7, Mozilla ,Firefox等瀏覽器中,javascript是內置有 XMLHttpRequest 這個對象的,但IE5 則沒有,需要用如下方法來啟動:
//IE 6
try{ xhttp = new ActiveXObject("Msxml2.XMLHTTP";} catch(e){ ; }
//IE5
if(xhttp == null) try { xhttp = new ActiveXObject("Microsoft.XMLHTTP";} catch(e){ ; }

  那考慮不同瀏覽器的兼容,啟動一個xmlhttp一般都要按如下方式:

CODE:[Copy to clipboard]var xhttp = null;

if(window.XMLHttpRequest){ //IE7, Mozilla ,Firefox 等瀏覽器內置該對象

xhttp = new XMLHttpRequest();

}else if(window.ActiveXObject){ //IE6、IE5

try{ xhttp = new ActiveXObject("Msxml2.XMLHTTP");} catch (e){ ; }

if( xhttp == null) try { xhttp = new ActiveXObject("Microsoft.XMLHTTP");} catch (e){; }

}

  對于 xmlhttp 的使用,一般遵守如下的順序:

  1、初始化 xmlhttp 對象(上文);

  2、打開鏈接

  方法

xhttp.open("GET", purl, true);

  參數一:用 GET 或 POST 方式發送數據

  參數二、請求網址(只能請求你服務器上的資源,一般瀏覽器安全限制不能讀取跨域的數據)

  參數三、true 表示異步傳輸(服務器返回信息完成前,你可以進行其它操作),false 表示阻斷方式的傳輸。

  3、設定要發送的 http 請求頭

  方法:

xhttp.setRequestHeader(key,value);

  一般來說,默認要發送的頭是:xhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded";

  這種表示發送的內容類型的請求頭用于發送文本數據,而且javascript默認是以unicode發送的,還有另外一種形式是:xhttp.setRequestHeader("Content-Type","multipart/form-data";這表示發送二制形式的數據,由于安全性原因,javascript一般不能用這種方式來發送數據,所以這個頭一般沒什么用。

  如果你的網站開啟了使用 refer 參數來防盜鏈,那么你必須用這個方法指定 Refer 參數,或者如果用戶需要登錄才能進行某操作,那么要指定 Cookie 的請求頭。

  4、send 數據

  方法:xhttp.send(postdata);

  對于用 get攻手請求,不需要指定postdata,直接用 test.php?a=a&b=b 這樣形式的網址來請求即可。

  如果是post方式,需要用 key1=value2&key2=value2 這樣的形式來對數據進行處理,把它合并在 postdata 字串中,然后發送。

  注意事項:

  javascript默認發送數據的方式是unicode,處理返回的數據必須是utf-8格式,因此,在發送的時候,需要用escape()函數來處理postdata和網址的value,在服務器上必須還原這些value,并把unicode轉為頁面編碼值,因此如果用 jsp 或 asp.net 都會比較簡單,但如果用php處理起來是什么費勁的,等下會教你如何做。

  5、確認服務器返回資料完成下載

  [1] 如果用阻斷的方式來發送請求,那么直接用 if(xhttp.readyState == 4)就能判斷是否完成。

readyState 的具體屬性值為:
0 沒open
1 沒send
2 狀態未知
3 正在傳送
4 傳送完成

  當然為了保障起見,還需要加多一重判斷,就是 if(xhttp.status == 200) ,status 就是 http 協議里的返回頭代碼

1xx 表示(唉呀,忘記了)
2xx 表示成功的信息
3xx 表示頁面轉移
4xx 頁面不存在
5xx 表示服務器的各種錯誤

  如果你的頁面沒特殊處理,一般用 if(xhttp.status == 200) 來確信內容返回是正確的

  [2] 如果用異步傳輸,需要用 onreadystatechange 的事件來監聽

xhttp.onreadystatechange = function()
{
//這里來進行上面阻斷方式的判斷
if(myajax.xhttp.readyState == 4){
if(myajax.xhttp.status == 200){
//要進行的后續操作
}
}
}

  6、獲取返回結果

屬性:
[1]xhttp.responseBody;
[2]xhttp.responseStream;
[3]xhttp.responseXml;
[4]xhttp.responseText;

  其中1、2都是二進制的方式,一般很少會用到,4不用看都知道了

  如果服務端無意外的話[3]返回的是一個xmldom的對象

  二、服務器部對xmlhttp請求的響應(PHP范例)

  為了簡化操作,在這里把 xmlhttp的各作操作封裝為一個類

  CODE:[Copy to clipboard]function DedeAjax(WiteOKFunc){ //WiteOKFunc 為異步狀態事件處理函數

//xmlhttp和xmldom對象
this.xhttp = null;
this.xdom = null;

//post或get發送數據的鍵值對
this.keys = Array();
this.values = Array();
this.keyCount = -1;

//http請求頭
this.rkeys = Array();
this.rvalues = Array();
this.rkeyCount = -1;
//請求頭類型
this.rtype = 'text';

//初始化xmlhttp
if(window.XMLHttpRequest){//IE7, Mozilla ,Firefox 等瀏覽器內置該對象
this.xhttp = new XMLHttpRequest();
}else if(window.ActiveXObject){//IE6、IE5
try { this.xhttp = new ActiveXObject("Msxml2.XMLHTTP");} catch (e) { }
if (this.xhttp == null) try { this.xhttp = new ActiveXObject("Microsoft.XMLHTTP");} catch (e) { }
}
this.xhttp.onreadystatechange = WiteOKFunc;
//rs: responseBody、responseStream、responseXml、responseText

//以下為成員函數
//--------------------------------

//初始化xmldom
this.InitXDom = function(){
var obj = null;
if (typeof(DOMParser) != "undefined") { // Gecko、Mozilla、Firefox
var parser = new DOMParser();
obj = parser.parseFromString(xmlText, "text/xml");
} else { // IE
try { obj = new ActiveXObject("MSXML2.DOMDocument");} catch (e) { }
if (obj == null) try { obj = new ActiveXObject("Microsoft.XMLDOM"); } catch (e) { }
}
this.xdom = obj;
};

//增加一個POST或GET鍵值對
this.AddKey = function(skey,svalue){
this.keyCount ;
this.keys[this.keyCount] = skey;
this.values[this.keyCount] = escape(svalue);
};

//增加一個Http請求頭鍵值對
this.AddHead = function(skey,svalue){
this.rkeyCount ;
this.rkeys[this.rkeyCount] = skey;
this.rvalues[this.rkeyCount] = svalue;
};

//清除當前對象的哈希表參數
this.ClearSet = function(){
this.keyCount = -1;
this.keys = Array();
this.values = Array();
this.rkeyCount = -1;
this.rkeys = Array();
this.rvalues = Array();
};

//發送http請求頭
this.SendHead = function(){
if(this.rkeyCount!=-1){ //發送用戶自行設定的請求頭
for(;i<=this.rkeyCount;i ){
this.xhttp.setRequestHeader(this.rkeys[i],this.rvalues[i]);
}
}
 if(this.rtype=='binary'){
this.xhttp.setRequestHeader("Content-Type","multipart/form-data");
}else{
this.xhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
}
};

//用Post方式發送數據
this.SendPost = function(purl){
var pdata = "";
var i=0;
this.state = 0;
this.xhttp.open("POST", purl, true);
this.SendHead();
if(this.keyCount!=-1){ //post數據
for(;i<=this.keyCount;i ){
if(pdata=="") pdata = this.keys[i] '=' this.values[i];
else pdata = "&" this.keys[i] '=' this.values[i];
}
}
this.xhttp.send(pdata);
};

//用GET方式發送數據
this.SendGet = function(purl){
var gkey = "";
var i=0;
this.state = 0;
if(this.keyCount!=-1){ //get參數
for(;i<=this.keyCount;i ){
if(gkey=="") gkey = this.keys[i] '=' this.values[i];
else gkey = "&" this.keys[i] '=' this.values[i];
}
if(purl.indexOf('?')==-1) purl = purl '?' gkey;
else purl = purl '&' gkey;
}
this.xhttp.open("GET", purl, true);
this.SendHead();
this.xhttp.send();
};

} // End Class DedeAjax
上面代碼保存為: dedeajax.js

ok 那現在做個最簡單的測試吧
test.htm

CODE:[Copy to clipboard]<script language='javascript' src='dedeajax.js'></script>
<script language='javascript'>
function WiteOK()
{
var myinfo = document.getElementById("myinfo");
if(myajax.xhttp.readyState == 4){
if(myajax.xhttp.status == 200){
myinfo.innerHTML = myajax.xhttp.responseText;
}
}
}
var myajax = new DedeAjax(WiteOK);
myajax.AddKey("key1","----------------------------");
myajax.SendPost("test.php");

</script>

<div id='myinfo'><div>
test.php


CODE:[Copy to clipboard]<?
header("Content-Type: text/html; charset=gb2312");
echo $_POST['key1'];
?>
看到了什么了呢?不用激動,真正讓你頭痛的東西還沒有出來。

把類里面的

CODE:[Copy to clipboard]this.AddKey = function(skey,svalue){
this.keyCount ;
this.keys[this.keyCount] = skey;
this.values[this.keyCount] = svalue;//escape(svalue);
};
escape 屏蔽掉

發送
myajax.AddKey("key1","-----中---國----人-----";

看到什么了,亂碼是吧?呵呵,這回開始頭大了

先把 escape放回去
this.values[this.keyCount] = escape(svalue);

那么看到的就是
-----%u4E2D---%u56FD----%u4EBA-----

如何把 %u4E2D 這些東西弄回來呢?對于php而言這是一個很復雜的問題,如果用asp就簡單多了

下面是我寫的一個函數:


CODE:[Copy to clipboard]//unicode url編碼轉gbk編碼函數
function Unicode2Gbk($str)
{
//載入對照詞典
if(!isset($GLOBALS['GbkUniDic']))
{
$ds = file("./data/gbk_unicode.dic");
foreach($ds as $l){
$GLOBALS['GbkUniDic'][hexdec('0x'.substr($l,0,4))] = substr($l,5,4);
}
}
//處理字符串
$glen = strlen($str);
$okstr = "";
for($i=0; $i < $glen; $i )
{
if( $glen-$i > 4){
if($str[$i]=='%' && $str[$i 1]=='u'){
$uni = hexdec('0x'.substr($str,$i 2,4));
if(isset($GLOBALS['GbkUniDic'][$uni])){
$uni = $GLOBALS['GbkUniDic'][$uni];
$okstr .= chr(hexdec(substr($uni,0,2))).chr(hexdec(substr($uni,2,2)));
}
else $okstr .= "&#{".hexdec("0x".$uni).";";
$i = $i 5;
}
else $okstr .= $str[$i];
}
else $okstr .= $str[$i];
}
return $okstr;
}
詞典文件: http://www.ce86.com/myimg/data.rar


把test.php 輸出改為

echo Unicode2Gbk($_POST['key1']);

正常了吧

以下說下面和xml有關的東西的了

  三、xmldom 的使用方法
  
  由于本文僅是牽針引線的作用,這一章就簡單些,因為針對的是 php ,如果針對的是 asp.net 或 jsp 寫涉及 web server 類的通信,已經不單純是 ajax 的問題了,本章的任務是把test2.php

CODE:[Copy to clipboard]<?
header("Content-Type: text/xml; charset=gb2312");
echo '<'.'?'."xml version=/"1.0/" encoding=/"gb2312/" ".'?'.">
<myhome>
<item sex=/"男/">我是小一</item>
<item sex=/"女/">我是小二</item>
</myhome>
";
?>這個xml文檔在客戶端用自己的方式展現出來。因為xml這種東西比較麻煩,所以語法也必須嚴格,test2.htm的頁面的源碼為

CODE:[Copy to clipboard]<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>ajax測試</title>
</head>
<body onload="WiteLoadDocument()">
<script language='javascript' src='dedeajax.js'></script>
<script language='javascript'>
var myajax = new DedeAjax(WiteOK);
function WiteOK()
{
var myinfo = document.getElementById("myinfo");
var mydom = null;
myinfo.innerHTML = "以下是處理結果:<br/>";
if(myajax.xhttp.readyState == 4){
mydom = myajax.xhttp.responseXml;
alert(mydom);
}
}
function WiteLoadDocument()
{
myajax.SendGet("test2.php");
}
</script>
<div id='myinfo'><div>
</body>
</html>
在IE中測試一下,如果彈出的對話框是 [object] 就表示成功獲得返回的xml的xmldoc了。

那下面是處理:

CODE:[Copy to clipboard]function WiteOK()
{
var myinfo = document.getElementById("myinfo");
var mydom = null;
myinfo.innerHTML = "以下是處理結果:<br/>";
if(myajax.xhttp.readyState == 4){
mydom = myajax.xhttp.responseXml;
var nodeList = mydom.selectNodes("/myhome/item");
var mynode = null;
var myatt = null;
var mysex = "";
for(i=1;i<=nodeList.length;i )
{
mynode = nodeList[i-1];
for(j=0;j < myinfo.attributes.length;j )
{
if(!mynode.attributes[j]) break;
myatt = mynode.attributes[j];
if(myatt.name=='sex') mysex = myatt.value;
}
myinfo.innerHTML = "我是:" mynode.text ",我的性別是:" mysex "<br/>";
}
}
}

結果:

CODE:[Copy to clipboard]以下是處理結果:
我是:我是小一,我的性別是:男
我是:我是小二,我的性別是:女
OK,目的已經達到

  關于dom的部份只在IE6中測試過,可能在firefox中會有問題,大家可能參考與兼容性有關的文檔。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产剧情日韩欧美| 国内精品久久久久| 国产精品成人国产乱一区| 91精品国产91久久久久| 欧美一区视频在线| 一区二区三区视频免费在线观看| 3344国产精品免费看| 亚洲综合一区二区不卡| 日韩精品中文字| 亚洲精品久久久久国产| 国产精品h在线观看| 国产欧美一区二区三区视频| 91免费欧美精品| 日本不卡高字幕在线2019| 97精品久久久中文字幕免费| 亚洲 日韩 国产第一| 中文字幕亚洲综合久久筱田步美| 国产精品草莓在线免费观看| 亚洲高清免费观看高清完整版| 日韩视频精品在线| 国产成人久久久精品一区| 精品美女久久久久久免费| 日韩大片免费观看视频播放| 中文字幕亚洲图片| 色婷婷亚洲mv天堂mv在影片| 国产精品va在线| 国产主播喷水一区二区| 日韩av一区在线观看| 欧美性视频在线| 欧美精品videossex性护士| 91精品国产高清久久久久久久久| 国产精品高潮粉嫩av| 亚洲影影院av| 亚洲国产精品视频在线观看| 国产精品视频一区二区高潮| 欧美激情一级精品国产| 日韩电影在线观看免费| 亚洲欧洲午夜一线一品| 高跟丝袜一区二区三区| 日本乱人伦a精品| 精品香蕉一区二区三区| 欧美丰满少妇xxxxx| 亚洲精品国精品久久99热一| 午夜精品久久久久久久白皮肤| 一区二区三区日韩在线| 中文字幕亚洲精品| 日韩欧美视频一区二区三区| 永久免费毛片在线播放不卡| 欧美综合激情网| 亚洲色图五月天| 国产精品777| 91精品视频观看| 亚洲一区美女视频在线观看免费| 97视频在线观看网址| 亚洲激情成人网| 久久亚洲精品网站| 在线观看免费高清视频97| 91福利视频网| 一区二区在线视频| 中文字幕精品在线视频| 97人人做人人爱| 国产精品中文字幕在线| 中文字幕欧美精品日韩中文字幕| 黄色一区二区在线观看| 激情亚洲一区二区三区四区| 国产午夜精品麻豆| 4388成人网| 国产一区二区在线播放| 米奇精品一区二区三区在线观看| 色久欧美在线视频观看| 欧美wwwxxxx| 国产成人免费av电影| 国产欧美日韩亚洲精品| www国产亚洲精品久久网站| 成人h片在线播放免费网站| 成人欧美一区二区三区黑人孕妇| www国产亚洲精品久久网站| 国产日韩欧美中文在线播放| 国精产品一区一区三区有限在线| 成人激情电影一区二区| 在线精品视频视频中文字幕| 黑人巨大精品欧美一区二区三区| 欧美一级bbbbb性bbbb喷潮片| 成人动漫网站在线观看| 久久久久亚洲精品国产| 欧美成人亚洲成人| 亚洲综合在线中文字幕| 正在播放欧美一区| 在线观看日韩av| 欧美精品免费看| 亚洲欧洲免费视频| 美女999久久久精品视频| 久久精品夜夜夜夜夜久久| 97在线精品视频| 中日韩美女免费视频网站在线观看| 最新国产精品拍自在线播放| 91干在线观看| 不卡av在线网站| 中文字幕一区电影| 一本色道久久综合狠狠躁篇的优点| 国产a∨精品一区二区三区不卡| 国产精品女人网站| 亚洲欧洲一区二区三区在线观看| 8090成年在线看片午夜| 国产精品男女猛烈高潮激情| 欧美在线一级va免费观看| 欧美性极品xxxx娇小| 久久偷看各类女兵18女厕嘘嘘| 日本道色综合久久影院| 久久99久久99精品中文字幕| 欧美丝袜一区二区三区| 97久久精品人人澡人人爽缅北| 日本久久91av| 国产精品丝袜高跟| 精品调教chinesegay| 91精品久久久久久久久久久久久久| 国产精品丝袜白浆摸在线| 亚洲精品成人网| 国产精品久久久久久久久免费看| www高清在线视频日韩欧美| 色天天综合狠狠色| 亚洲91av视频| 最好看的2019年中文视频| 欧美性受xxxx黑人猛交| 亚洲精品国产精品国自产观看浪潮| 综合国产在线视频| 亚洲精品资源美女情侣酒店| 91久久精品国产91久久| 亚洲电影成人av99爱色| 亚洲free性xxxx护士白浆| 国产日产欧美a一级在线| 欧洲亚洲妇女av| 久久福利视频导航| 日韩视频―中文字幕| 日韩在线观看成人| 国产精品亚洲综合天堂夜夜| 国产v综合ⅴ日韩v欧美大片| 欧日韩不卡在线视频| 欧美电影免费播放| 亚洲国产另类 国产精品国产免费| 国产精品色婷婷视频| 最好看的2019年中文视频| 欧美人成在线视频| 中文字幕欧美精品在线| 色老头一区二区三区在线观看| 欧美国产日韩一区二区在线观看| 成人亚洲综合色就1024| 欧美噜噜久久久xxx| 国产一区二区三区视频| 中文字幕日韩av电影| 亚洲精品国产精品乱码不99按摩| 国产高清视频一区三区| 中文字幕欧美日韩精品| 亚洲码在线观看| 欧洲成人性视频| 在线观看亚洲视频| 亚洲国产日韩欧美在线图片| 日韩在线视频免费观看高清中文| 亚洲人成欧美中文字幕| 久99九色视频在线观看| 国产suv精品一区二区三区88区| 亚洲精品99久久久久中文字幕| 亚洲成人动漫在线播放| 国产女同一区二区|