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阅读 156,423评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,339评论 1 289
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,241评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,503评论 0 203
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,824评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,262评论 1 207
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,615评论 2 309
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,337评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 33,989评论 1 238
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,300评论 2 240
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,829评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,193评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,753评论 3 230
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 25,970评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,708评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,295评论 2 267
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,207评论 2 258

推荐阅读更多精彩内容

  • 1- 关于 ajax 及其作用 Ajax是Asynchronous JavaScript and XML的缩写。...
    osborne阅读 486评论 0 0
  • ajax 是什么?有什么作用? AJAX的全称是Asynchronous JavaScript and XML(异...
    cross_王阅读 319评论 0 0
  • 在了解ajax之前,我们先粗略的了解一下http协议 HTTP协议 http事务 一个完整的http请求是怎样的呢...
    YM雨蒙阅读 294评论 0 4
  • 题目1: ajax 是什么?有什么作用? ajax是一种技术方案,但并不是一种新技术。它依赖的是现有的CSS/HT...
    萧雪圣阅读 275评论 0 0
  • 题目1: ajax 是什么?有什么作用? 含义:脚本发起HTTP通信 作用:传输数据到服务器,监听状态码实现服务器...
    从前慢pearl阅读 116评论 0 0