JavaScrip之初识Ajax


什么是Ajax?

ajax是一种技术方案,但并不是一种新技术。它依赖的是现有的CSS/HTML/Javascript,而其中最核心的依赖是浏览器提供的XMLHttpRequest对象,是这个对象使得浏览器可以发出HTTP请求与接收HTTP响应。 实现在页面不刷新的情况下和服务端进行数据交互


如何实现Ajax?

  • XMLHttpRequest对象
  • fetch

XMLHttpRequest的用法、属性

1.创建XHR对象

var xhr = new XMLHttpRequest();

2.xhr.open()

接受三个参数

  • 1.要发送的请求的类型("get"、"post"),
    1. 请求的URL
    1. 是否异步发送请求的布尔值

3.xhr.send()

接受一个参数

  • 1.请求主体发送的数据,不需要则传入(null)

4.xhr.responseText:作为响应主体被返回的文本

5.xhr.responseXML:如果响应的内容类型是"text/html"或"application/xml",这个属性中将保存包含着响应数据的XML DOM文档

6.xhr.status:响应的HTTP状态

7.xhr.statusText:HTTP状态的说明

8.xhr.readyState:请求/响应过程的当前活动阶段

  • 0:未初始化。尚未调用open()方法。
  • 1:启动。已经调用open()方法,但尚未调用send()方法。
  • 2:发送。已经调用send()方法,但尚未接收到响应。
  • 3:接收。已经接收到部分响应数据。
  • 4:完成。已经接收到全部数据,而且已经可以在客户端使用。
    说明:可以把xhr.readyState属性和TCP/IP的三次握手类比一下,1,2表示第一次,3表示第二次,4表示第三次。只要readyState属性变一次,就会触发一次readyState事件。还要强调一点的是必须在调用open()之前指定onreadystatechage事件处理程序才能确保跨浏览器兼容性。

9.xhr.abort():取消异步请求,在接收响应之前使用

10.xhr.setRequestHeader():设置自定义的请求头部信息。

在调用open()方法之后,send()方法之前使用。

11.xhr.timeout:表示请求在等待响应多少毫秒之后就终止。

12.xhr.overrideMimeType():用于重写响应的MIME类型。

比如服务器返回的MIME类型时text/plain,但数据实际包含的是XML,根据MIME类型,即使数据是XML,responseXML属性仍然是null,通过调用该方法,可以保证把响应当作XML而非纯文本使用。调用方法必须在send()之前使用

var xhr = new XMLHttpReququest()
xhr.open("get","text.php",true)
xhr.overrideMimeType("text/html")
xhr.send(null)

具体实现Ajax

1.同步实现Ajax

hello.html

    //同步执行Ajax
    var xhr=new XMLHttpRequest();
    xhr.open('GET','/hello.json',false);
    xhr.send();
    var data=xhr.responseText;
    console.log(data);

hello.json

{
  "name":"Ajax"
}

首先我们打开命令行本地服务器,不然会报错。

报错

接下来执行


大家可以看到红色框的英文,大概意思就是主线程上的同步XMLHttpRequest由于对最终用户体验的不利影响而被淘汰。如需更多帮助,请检查。所以我们需要使用异步执行Ajax


2. 请求方式为GET异步实现Ajax

hello.html

 //   异步执行Ajax
    var xhr=new XMLHttpRequest();
    xhr.open('GET','/hello.json',true);
    xhr.send();
    xhr.addEventListener('load',function(){
    var data=xhr.responseText;
    console.log(data);
    });

hello.json

{
  "name":"Ajax"
}
image.png

大家注意一下,这里用Ajax向本地服务器请求的是/hello.json ,返回的数据类型是什么?是json对象还是什么?我们可以验证一下。在源代码添加一句 typeof data

image.png

结果为string


假如我们在open()当中输入错误的会发现什么状况呢?

404 not found

可以看到404 not found,404是http状态码,最开始执行成功状态码为200,于是我们可以继续改进代码,通过状态码判断是否执行
hello.html

   var xhr=new XMLHttpRequest();
    xhr.open('GET','/hello.json',true);
    xhr.send();
  
    xhr.addEventListener('load',function(){
      console.log(xhr.status);
      if((xhr.status>=200&&xhr.status<300)||xhr.status==304){
      var data=xhr.responseText;
      console.log(data);
      }
      else{ 
        console.log('error');
      }
    });
    //当网络出现故障的时候
    xhr.error=function(){
      console.log("error");
    }
当文件路径没有出错的时候

假如我们要监听当前执行的状态,该怎么做?
hello.html

    //监听状态
    var xhr=new XMLHttpRequest();

    console.log('readystatus:',xhr.readyState);
    //使用readystatechange事件监听状态
    xhr.addEventListener('readystatechange',function(){
      console.log('readystatus:',xhr.readyState);
    })
    xhr.addEventListener('load',function(){
      console.log(xhr.status);
      if((xhr.status>=200&&xhr.status<300)||xhr.status==304){
      var data=xhr.responseText;
      console.log(data);
      }
      else{ 
        console.log('error');
      }
    });
    xhr.open('GET','/hello.json',true);
    xhr.send();

如果路径出错则是下图这种状况

image.png

由于是错误的路径,所以没有readyState:3,因为3表示接受响应数据,这步是不可能有的。

3.请求方式为POST异步实现Ajax

  var xhr = new XMLHttpRequest()
  xhr.timeout = 3000        //可选,设置xhr请求的超时时间
  xhr.open('POST', '/login', true)

  xhr.onload = function(e) { 
    if((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304){
      console.log(this.responseText)
    }
  }
    //可选
  xhr.ontimeout = function(e) { 
        console.log('请求超时')
  }

  //可选
  xhr.onerror = function(e) {
      console.log('连接失败')
  }
  //可选
  xhr.upload.onprogress = function(e) {
      //如果是上传文件,可以获取上传进度
  }

  xhr.send('username=jirengu&password=123456')  

POST方式将数据放到send()中

4.封装Ajax

  function ajax(opts){
    var url = opts.url
    var type = opts.type || 'GET'
    var dataType = opts.dataType || 'json'
    var onsuccess = opts.onsuccess || function(){}
    var onerror = opts.onerror || function(){}
    var data = opts.data || {}

    var dataStr = []
    for(var key in data){
        dataStr.push(key + '=' + data[key])
    }
    dataStr = dataStr.join('&')

    if(type === 'GET'){
        url += '?' + dataStr
    }

    var xhr = new XMLHttpRequest()
    xhr.open(type, url, true)
    xhr.onload = function(){
        if((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304){
            //成功了
            if(dataType === 'json'){
                onsuccess( JSON.parse(xhr.responseText))
            }else{
                onsuccess( xhr.responseText)
            }
        } else {
            onerror()
        }
    }
    xhr.onerror = onerror
    if(type === 'POST'){
        xhr.send(dataStr)
    }else{
        xhr.send()
    }
}

ajax({
    url: 'http://api.jirengu.com/weather.php',
    type:'POST',
    dataType:'TEXT',
    data: {
        city: '北京'
    },
    onsuccess: function(ret){
        console.log(ret)
        render(ret)  //浏览器渲染
    },
    onerror: function(){
        console.log('服务器异常')
        showError()   //错误浏览器渲染
    }
})
function render(json){
    //拼装成dom输入页面中
}
function showError(){
  //错误提示
}

sever mock

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容