欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Ajax與服務器(JSON)通信實例

 更新時間:2016年11月04日 14:42:12   作者:畫個女孩陪著我  
本篇文章主要介紹了使用Ajax與服務器(JSON)通信方法,Ajax提供了兩類服務器通信手段:同步通信和異步通信。有需要的可以了解一下。

 Ajax這個詞,不代表任何東西,它僅僅是稱呼一系列促進客戶端與服務器通信的技術時所用的一個術語。服務器通信時Ajax技術的核心內容,其目標就是從客戶端向服務器發(fā)送信息,并接受后者的回傳,以求在此過程中創(chuàng)建出更好地打用戶體驗來。

Ajax之前所有的服務器通信都是在服務器上完成的,所以那是若想重繪頁面的一部分,要么使用iframe(已淘汰),要么刷新整個頁面。這兩種方式都稱不上是良好的用戶體驗。

Ajax提供了兩類服務器通信手段:同步通信和異步通信。

異步通信Ajax比同步通信要常見的多了,大概是98%的使用頻次。異步意味著此類Ajax調用并不和其他任務同時觸發(fā),這種通信行為發(fā)生在后臺,具備相當?shù)莫毩⑿?,與頁面和web應用程序相互分離。

使用異步調用,可以避免同步調用的阻塞性,它不需要與頁面中的其他HTTP請求擠在一起處理。

XMLHttpRequest對象

XMLHttpRequest對象是所有Ajax調用的核心。我們的目的是使用Ajax技術異步獲取JSON中的數(shù)據(jù),并以適當?shù)男问綄⑵湔宫F(xiàn)出來:

//創(chuàng)建ajax通信服務器對象

function getHTTPObject(){

  "use strict"; //注意使用嚴格模式

  var xhr;

  //使用主流的XMLHttpRequest通信服務器對象

  if(window.XMLHttpRequest){

    xhr = new window.XMLHttpRequest();

  //如果是老版本ie,則只支持Active對象
  } else if(window.ActiveXObject){

    xhr = new window.ActiveXObject("Msxml2.XMLHTTP");
  }

  //將通信服務器對象返回
  return xhr;

}

跨瀏覽器的兼容問題:微軟Ie起初發(fā)明了XMLHttp對象,那就導致了IE5、IE6只支持ActiveXObject對象,所以要考慮對它的兼容問題。

創(chuàng)建Ajax調用

首先,我在本地的data目錄下創(chuàng)建好了Salad.json文件,等待Ajax程序去調用它:

//ajax JSON Salad
var ingredient = {
  "fruit":[
    {
      "name" : "apple",
      "color" : "green"
    },
    {
      "name" : "tomato",
      "color" : "red"
    },
    {
      "name" : "peach",
      "color" : "pink"
    },
    {
      "name" : "pitaya",
      "color" : "white"
    },
    {
      "name" : "lettuce",
      "color" : "green"
    }
  ]
};

然后要做的是向服務器發(fā)送請求和接受傳回的數(shù)據(jù):

在接收到返回的服務器通信對象“xhr”后,我們緊接著要做的是使用readystatechange 事件對通信對象 “xhr”進行 Ajax請求狀態(tài)和服務器狀態(tài),當readystate狀態(tài)請求完成和status狀態(tài)服務器正常時在進行之后 的通信工作。

//輸出ajax調用所返回的json數(shù)據(jù)

var request = getHTTPObject();

request.onreadystatechange = function(){

  "use strict";

    //當readyState全等于“4”狀態(tài),status全等于“200”狀態(tài) 代表服務器狀態(tài)服務及客戶端請求正常,得以返回
  if(request.readyState ===4 || request.status ===200 ){
    
    //為了方便起見,將數(shù)據(jù)打印到瀏覽器控制臺(F12查看)
    console.log(request.responseText);
  }
  
  //使用GET方式請求.json數(shù)據(jù)文件,并且不向服務器發(fā)送任何信息
  request.open("GET","data/ingredient.json",true);
  request.send(null);
};

Ajax也通過GET和POST方法進行調用,GET方式會把數(shù)據(jù)暴露在URL之中,所以它的處理工作較少;POST相對較安全,但性能不如GET。   接下來分別使用 open()和 send()方法對服務器請求數(shù)據(jù)文件和發(fā)送數(shù)據(jù)。

通常在實際的開發(fā)項目中,不可能僅僅有一個Ajax調用。為了復用,為了方便起見,我們需要將這個Ajax程序封裝成復用函數(shù),在這里我傳入了一個outputElement參數(shù),用于給用戶提示等待;還傳入了一個callback參數(shù),用于傳入一個回調函數(shù),根據(jù)用戶在搜索框鍵入的關鍵字在JSON文件中進行匹配,將合適的數(shù)據(jù)渲染到頁面響應的位置:

//將其封裝成一個供調用函數(shù)

function ajaxCall(dataUrl,outputElement,callback){
  "use strict";  //這是一段截取的js(ajax)代碼

  var request = getHTTPObject();
  //我想要提醒大家的是:當網(wǎng)頁的某個區(qū)域在向服務器發(fā)送http請求的過程中,要有一個標識提醒用戶正在加載...

  outputElement.innerHTML = "Loding..."; //也可以根據(jù)各位的需求添加一個循環(huán)小動畫

  request.onreadystatechange = function () {

    if(request.readyState ===4 || request.status ===200){

      //將request.responseText返回的數(shù)據(jù)轉化成JSON格式
      var contacts = JSON.parse(request.responseText);
      
      //如果回調函數(shù)是function類型,則使用callback函數(shù)處理返回的JSON數(shù)據(jù)
      if(callback === "function"){
        callback(contacts);
      }
    }
  };

  request.open("GET","data/ingredient.json",true);
  request.send(null);
}

然后調用 ajaxCall():

//調用程序,我們將使用Ajax請求的JSON數(shù)據(jù)顯示到HTML文檔的某個區(qū)域中!
(function () {
  "use strict";

    //下面將給出DOM語句相對應的HTML代碼
  var searchForm = document.getElementById("search-form"),
    searchField = document.getElementById("q"),
    getAllButton = document.getElementById("get-all"),
    target = document.getElementById("output");

  var search = {

    salad : function(event){

      var output = document.getElementById("output");
        //請求的JSON數(shù)據(jù)文件名,輸出到HTML的區(qū)域,檢索數(shù)據(jù)文件的核心function語句

      ajaxCall('data/ingredient.json','output',function(data){

        //searchValue為搜索條目,準備循環(huán)檢索
        var searchValue = searchField.value,

          //找到食材條目(詳見JSON數(shù)據(jù)文件)
          fruit = data.fruit,

          //統(tǒng)計水果的數(shù)量
          count = fruit.length,
          i;

        //阻止默認行為
        event.preventDefault();

        //初始化
        target.innerHTML = "";

        if(count > 0 || searchValue !==""){
          for(i = 0;i < count;i++){
            
            var obj = fruit[i],
              //將name與searchvalue值相匹配,如果值不等于 -1,那么就確定兩者相匹配

              inItfount = obj.name.indexOf(searchValue);

            //將JSON中匹配的數(shù)據(jù)規(guī)范的寫入到DOM
            if(isItfount != -1){
              target.innerHTML += '<p>'+obj.name+'<a href="mailto:" '+obj.color+'>'+obj.color+'</a></p>'
            }
          }
        }
      })
    }
  };
  //事件監(jiān)聽器,監(jiān)聽鼠標單擊事件后調用函數(shù)并請求JSON數(shù)據(jù)文件
  searchField.addEventListener("click",search.salad,false);
  
})();

Ajax 所對應的HTML文檔:

<h1>制作沙拉所需要的食材</h1>

  <form action="" method="get" id="search-form">

    <div class="section">

      <label for="q">搜索食材</label>
      <input id="q" name="q" required placeholder="type a name">
    </div>


    <div class="button-group">

      <button type="submit" id="btn-search">搜索</button>
      <button type="button" id="get-all">get all contacts</button>

    </div>

  </form>

  <div id="output"></div>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 一個鼠標移動滑出層效果的實現(xiàn)代碼

    一個鼠標移動滑出層效果的實現(xiàn)代碼

    一個鼠標移動滑出層的代碼,根據(jù)網(wǎng)上的視頻教程學習的,這也算是第一次練手吧,鼠標靠近復選框的時候,就會顯示出一個層,移開則消失。
    2011-08-08
  • 使用taro開發(fā)微信小程序遇到的坑總結

    使用taro開發(fā)微信小程序遇到的坑總結

    Taro,京東凹凸實驗室出品的適配多端的一個框架,這篇文章主要介紹了使用taro開發(fā)微信小程序遇到的坑總結,需要的朋友可以參考下
    2019-04-04
  • Bootstrap實現(xiàn)可折疊分組側邊導航菜單

    Bootstrap實現(xiàn)可折疊分組側邊導航菜單

    這篇文章主要介紹了Bootstrap實現(xiàn)可折疊分組側邊導航菜單的相關資料,需要的朋友可以參考下
    2018-03-03
  • IE6與IE7中,innerHTML獲取param的區(qū)別

    IE6與IE7中,innerHTML獲取param的區(qū)別

    最近,在用一些web編輯器,發(fā)現(xiàn)插入一段mp3后,查看源代碼,object標簽中的param都被刪除。下面我演示給大家看看。
    2009-03-03
  • JavaScript數(shù)組復制詳解

    JavaScript數(shù)組復制詳解

    對于javascript來說,數(shù)組是一種引用類型,如果只是一維數(shù)組的話,復制還較為容易,如果是多維數(shù)組呢?如何實現(xiàn)多維數(shù)組的深度復制?
    2017-02-02
  • 深入理解JavaScript系列(9) 根本沒有“JSON對象”這回事!

    深入理解JavaScript系列(9) 根本沒有“JSON對象”這回事!

    寫這篇文章的目的是經(jīng)??吹介_發(fā)人員說:把字符串轉化為JSON對象,把JSON對象轉化成字符串等類似的話題,所以把之前收藏的一篇老外的文章整理翻譯了一下,供大家討論,如有錯誤,請大家指出,多謝
    2012-01-01
  • 淺談Javascript數(shù)組索引

    淺談Javascript數(shù)組索引

    這篇文章主要介紹了淺談Javascript數(shù)組索引,都是個人的一些經(jīng)驗總結,需要的朋友可以參考下
    2015-07-07
  • 深入淺析search 搜索框的寫法

    深入淺析search 搜索框的寫法

    本文以京東搜索框為例給大家淺析search 搜索框的寫法,本文介紹的非常不錯,需要的朋友可以參考下
    2016-08-08
  • 小程序分享模塊超級詳解(推薦)

    小程序分享模塊超級詳解(推薦)

    這篇文章主要介紹了小程序分享模塊超級詳解(推薦),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • js 判斷文件類型并控制表單提交示例代碼

    js 判斷文件類型并控制表單提交示例代碼

    判斷文件類型控制表單提交這些都是在客戶端實現(xiàn)的,下面有個不錯的示例,感興趣的朋友可以參考下
    2013-11-11

最新評論