Ajax基本使用get/post

  • AJAX
  • Asynchronous JavaScript And XML 的首字母縮寫
  • AJAX 并不是一種新的編程語言,而僅僅是一種技術方案,它可以創建更好、更快且交互性更強的 web 應用程序。
  • 本質是在HTTP協議的基礎上通過異步的方式與服務器進行通信
  • 功能:
    可以不用跳轉新界面, 就可以發送請求。
    可以直接和服務器進行交互。
  • 同步和異步的概念解釋
  • 指某段程序執行時不會阻塞其它程序執行,其表現形式為程序的執行順序不依賴程序本身的書寫順序,相反則為同步
  • 同步:一個做完才能做另外一個
  • 異步:把一個任務交給其他人,自己做另外一個,兩人一塊做
  • XMLHttpRequest
  • 瀏覽器內建對象,用于在后臺與服務器通信(交換數據) , 由此我們便可實現對網頁的部分更新,而不是刷新整個頁面。
  • get請求使用步驟
  • 1.創建請求對象(找個電話)
    new XMLHttpRequest()
    new ActiveXObject('Microsoft.XMLHTTP'); 支持IE5.6
var xhr;
 if (window.XMLHttpRequest) {
          xhr = new XMLHttpRequest();
}else {
          xhr = new ActiveXObject('Microsoft.XMLHTTP');
}
  • 2.設置請求方式、URL地址、同異步(輸入電話號碼)
// 參數1: 請求方式
// 參數2: 請求的url
// 參數3: 是否是異步
xhr.open('get', '01-ajax-base-server.php', true);
  • 3.發送請求(撥出號碼)
xhr.send();
  • 4.監聽服務器響應 (等待電話接通)
xhr.onreadystatechange = function () {  }
判斷readyState
if (xhr.readyState == 4) {
判斷狀態碼status
      var status = xhr.status;
      if (status >= 200 && status < 300 || status == 304) {
          執行第5步
        }
}
  • readyState
    0:請求未初始化(還沒有調用open())
    1:請求已經建立,但是還沒有發送(還沒有調用send())
    2:請求已發送,正在處理中(通常現在可以從響應中獲取內容頭)
    3:請求在處理中;通常響應中已有部分數據可用了,但是服務器還沒有完成響應的生成
    4:響應已完成;您可以獲取并使用服務器的響應了
  • 5.處理返回(響應)數據(你聽到對方說話)
在第四步的函數中處理
xhr.responseText     獲得字符串形式的響應數據。
xhr.responseXML    獲得 XML 形式的響應數據。
  • Ajax-get請求參數與緩存
  • 如何把數據傳送到服務器
    直接拼接到url地址后面即可
    url?name=sz&age=18
// 拿到本地需要傳送的數據
var account = document.getElementById('account').value;
var pwd = document.getElementById('pwd').value;
 設置請求的目標url (輸入電話號碼)
                // 參數1: 請求方式
                // 參數2: 請求的url
                // 參數3: 是否是異步
xhr.open('get', '01-ajax-base-server.php?account=' + account + '&pwd=' + pwd, true);
  • 注意:IE瀏覽器下的get請求緩存問題,如果發送的請求,是同一個URL地址,則瀏覽器會返回之前響應的緩存
  • 原因:一個相同的URL地址,一般只有一個結果, 所以,第二次訪問的時候, 如果URL字符串沒有變化,IE瀏覽器則直接使用之前的結果
  • 解決方案:生成隨機數拼接到URL地址后面
 function getRandomStr() {
            return Math.random() + (new Date()).getTime();
        }
xhr.open('get', '01-ajax-base-server.php?account=' + account + '&pwd=' + pwd + '&random=' + getRandomStr(), true);
  • post請求與get請求區別
  • 第二步中,將open的請求參數改為post即可
  • 第二步中,不能將參數放在URL后面。應該在第三步send方法中傳遞
xhr.send('name=sz&age=19');
  • 注意:在第二步open之后,第三步send之前需要添加:
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
//Content-Type防止亂碼
  • 從發起請求到響應成功的完整寫法示例:
/*js 內置的 http 請求對象  XMLHttpRequest*/
/*1.初始化這個內置對象*/
var xhr = new XMLHttpRequest();
/*2.請求報文*/
/*請求行*/
xhr.open('post','01.php');
/*請求頭*/
//get  沒有必要設置
//post 必須設置 Content-Type: application/x-www-form-urlencoded
xhr.setRequestHeader('content-Type','application/x-www-form-urlencoded');
/*請求主體*/
//get: xhr.send(null);
//post: xhr.send("數據");
xhr.send("name=xzz&age=10");/*發送請求*/
/*3.響應報文*/
xhr.onreadystatechange = function () {
    if(xhr.readyState == 4){/*通訊完全完成*/    
        if(xhr.status == 200){/*響應成功*/      
            document.querySelector('body').innerHTML = xhr.responseText;//渲染頁面
        }
    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,739評論 6 534
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,634評論 3 419
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,653評論 0 377
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,063評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,835評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,235評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,315評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,459評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,000評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,819評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,004評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,560評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,257評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,676評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,937評論 1 288
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,717評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,003評論 2 374

推薦閱讀更多精彩內容