ajax實踐

ajax 是什么?有什么作用?

Asynchronous javascript and XML 即異步的JS和XML
是前后端數據交互的一種方法
通過原生的XMLHttpRequest對象,發出HTTP請求,并以異步方式(絕大多數時候)從服務器獲取信息
優點
更新數據而不需要刷新頁面: 它能在不刷新整個頁面的前提下與服務器通信維護數據,由于ajax是按照需求請求數據,避免發送那些沒有改變的數據。
異步通信: 它與服務器使用異步的方式通信,不會打斷用戶的操作(卡死頁面)。
前后端負載平衡: 可以將后端服務器的一些工作轉移給客戶端,利用客戶端限制的能力來處理,減輕了服務器的負擔。
數據與呈現分離: 利于分工,降低前后耦合。
缺點
瀏覽器歷史記錄的遺失: 在使用AJAX對頁面進行改變后,由于并沒有刷新頁面,沒有改變頁面的訪問歷史,當用戶想要回到上一個狀態時,無法使用瀏覽器提供的后退。
AJAX的安全問題: AJAX的出現就像建立起了一直通服務器的另一條通道,容易遭受到一些攻擊。

前后端開發聯調需要注意哪些事情?后端接口完成前如何 mock 數據?

約定數據:名稱、類型等
約定借口:名稱、格式、參數等
根據約定整理成接口文檔
前端人員可以自己使用服務器框架搭建一個模擬服務器環境,比如express&nodejs或xampp或server-mock。

點擊按鈕,使用 ajax 獲取數據,如何在數據到來之前防止重復點擊?

var isOk = true;  //設置狀態鎖
btn.onclick =function(){
    if(!isOk){return} //狀態鎖沒開直接返回
    isOk = false;//關閉狀態鎖
    var XHR = new XMLHttpRequest();
    XHR.open("GET","/json/page"+index+".json");
    index++;
    XHR.onreadystatechange = function(req,res){
        if(XHR.readyState===4){
            if(XHR.status===200){
                success(XHR.response);  
            }else{
                console.log("錯誤:"+XHR.status)
            }
            isOk = true;  //打開關閉狀態鎖
        }
    }
    XHR.send();
}

實現加載更多的功能,后端在本地使用server-mock來模擬數據

var btn = document.getElementById("clickme");
var box = document.getElementsByClassName("wrap")[0];
var index = 1;
var isOk = true;
btn.onclick =function(){
    ajax(success);
}
function ajax(callback){
    if(!isOk){return}
    isOk = false;
    var XHR = new XMLHttpRequest();
    XHR.open("GET","/json/page"+index+".json");
    index++;
    XHR.onreadystatechange = function(req,res){
        if(XHR.readyState===4){
            if(XHR.status===200){
                callback(XHR.response); 
            }else{
                console.log("錯誤:"+XHR.status)
            }
            isOk = true;
        }
    }
    XHR.send();
}
function success(response){

    var obj = JSON.parse(response);
    for(var i=0;i<obj.length;i++){
        var newItem = document.createElement("div");
        newItem.className = "item";
        newItem.innerHTML = `<p class="title">`+obj.item[i].title+`</p>
          <p class="content">`+obj.item[i].content+`</p>`;
        box.insertBefore(newItem,btn);
    }
    console.log(obj);
    if(!obj.hasNext){
        btn.className="unclicked";
        btn.innerText = "沒有更多了";
        isOk = false;
    }
}

后端

var http = require('http')
var fs = require('fs')
var url = require('url')

//console.log(Object.keys(http))
var port = process.env.PORT || 8888;

var server = http.createServer(function(req, res){

  var temp = url.parse(req.url, true)
  var path = temp.pathname
  var query = temp.query
  var method = req.method

  if(path==="/index.html"||path==="/"){
    var string = fs.readFileSync("index.html");
    res.setHeader("Content-type","text/html")
    res.end(string)
  }else
  if(path==="/css/main.css"){
    var string = fs.readFileSync("css/main.css");
    res.setHeader("Content-type","text/css")
    res.end(string)
  }else
  if(path==="/js/main.js"){
    var string = fs.readFileSync("js/main.js");
    res.setHeader("Content-type","text/javascript")
    res.end(string)
  }else
  if(path.slice(1,5)==="json"){
    var string = fs.readFileSync(path.slice(1));
    res.setHeader("Content-type","application/json");
    setTimeout(function(){res.end(string)},0);
    
  }else
  if(path==="/img/new1.jpg"){
    var string = fs.readFileSync(path.slice(1));
    res.setHeader("Content-type","application/x-jpg");
    res.end(string)
  }
  

  console.log(method + ' ' + req.url)
})

server.listen(port)
console.log('監聽 ' + port + ' 成功,打開 http://localhost:' + port)
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,362評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,577評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,486評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,852評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,600評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,944評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,944評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,108評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,652評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,385評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,616評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,111評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,798評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,205評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,537評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,334評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,570評論 2 379

推薦閱讀更多精彩內容

  • 1- 關于 ajax 及其作用 Ajax是Asynchronous JavaScript and XML的縮寫。...
    osborne閱讀 546評論 0 0
  • ajax 是什么?有什么作用? AJAX的全稱是Asynchronous JavaScript and XML(異...
    cross_王閱讀 339評論 0 0
  • 在了解ajax之前,我們先粗略的了解一下http協議 HTTP協議 http事務 一個完整的http請求是怎樣的呢...
    YM雨蒙閱讀 329評論 0 4
  • 題目1: ajax 是什么?有什么作用? ajax是一種技術方案,但并不是一種新技術。它依賴的是現有的CSS/HT...
    蕭雪圣閱讀 290評論 0 0
  • 題目1: ajax 是什么?有什么作用? 含義:腳本發起HTTP通信 作用:傳輸數據到服務器,監聽狀態碼實現服務器...
    從前慢pearl閱讀 146評論 0 0