zoukankan      html  css  js  c++  java
  • 原生ajax 请求

    什么是ajax

    AJAX 是一种用于创建快速动态网页的技术。

    通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。

    这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新,也就是我们所说的局部更新。

    简单示例

    function play(){
                var ajax = new XMLHttpRequest();
                ajax.open("get","https://api.apiopen.top/recommendPoetry");
                ajax.setRequestHeader("Content-type","application/x-www-form-urlencoded");
                ajax.send();
                ajax.onreadystatechange=function(){
                    if(ajax.readyState == 4 && ajax.status == 200){
                        console.log(JSON.parse(ajax.responseText));
                    }
                }
            }
    play();

    XMLHttpRequest 对象

    如果需要使用ajax 我们需要创建一个XMLHttpRequest对象。代码如下:

    var ajax = new XMLHttpRequest();
     
     
    open()方法

    它接收3个参数:

      1.method:请求类型,如get、post。

      2.url:请求地址。

      3.async:规定当前请求是否异步,默认(不填)是异步的。(true为异步,false为同步)

     
    ajax.open("get","https://api.apiopen.top/recommendPoetry");
     
     
    setRequestHeader方法

    接下来我们通过setRequestHeader方法设置请求头。注意:这个方法必须要在open()方法执行之后才能设置。(也就是必须先调用open()方法)。代码如下:

    ajax.setRequestHeader("Content-type","application/x-www-form-urlencoded");

    send方法

    send方法表示将请求发送到服务器。

    当请求类型为post时,send()方法接受一个参数,就是你需要传给后台的参数。get请求可以不填或者填null

    ajax.send();

    这时请求已经发送出去了,那我们如何知道服务器是否接收到了请求?如何接收服务器给我们的响应呢?

    readyState属性

    readyState是XMLHttpRequest对象中的一个属性,它存有服务器响应给我们的状态信息。readyState属性一共有5个值:

    • 0: 请求未初始化(代理被创建,但尚未调用 open() 方法)
    • 1: 服务器连接已建立(open方法已经被调用)
    • 2: 请求已接收(send方法已经被调用,并且头部和状态已经可获得)
    • 3: 请求处理中(下载中,responseText 属性已经包含部分数据)
    • 4: 请求已完成,且响应已就绪(下载操作已完成)

    onreadystatechange方法

    每当readyState属性改变时,就会触发onreadystatechange()方法,所以我们可以在这个方法里面去获取服务器给我们的响应。

    当readyState的值等于4的时候,表示请求已经完成,并且服务器已经把结果返回给我们了。

    ajax.onreadystatechange=function(){
       //readyState等于4  并且status等于200(表示请求成功)
      if(ajax.readyState==4 && ajax.status==200){
          console.log(ajax.responseText);//服务器响应的结果
      }  
    }

    responseText和responseXML属性

    responseText:获得字符串形式的响应数据。

    responseXML:获得XML形式的响应数据。

    我们上面使用的是responseText属性,但一般需要的是json格式数据,我们可以使用JSON.parse()让字符串转换成json对象。代码如下:

    ajax.onreadystatechange=function(){
       //readyState等于4  并且status等于200(表示请求成功)
      if(ajax.readyState==4 && ajax.status==200){
          console.log(JSON.parse(ajax.responseText));//服务器响应的结果
      }  
    }
  • 相关阅读:
    [LeetCode] 303. 区域和检索
    [LeetCode] 120. 三角形最小路径和 ☆☆☆(动态规划 范例)
    [LeetCode] 18. 四数之和 ☆☆☆(双指针)
    [LeetCode] 16. 最接近的三数之和 ☆☆☆(双指针)
    [LeetCode] 109. 有序链表转换二叉搜索树 ☆☆☆(递归)
    优惠券模块设计要点
    nginx upstream 实现负载均衡
    nginx fastcgi配置
    nginx rewrite规则
    nginx Location 配置
  • 原文地址:https://www.cnblogs.com/huancheng/p/10318203.html
Copyright © 2011-2022 走看看