zoukankan      html  css  js  c++  java
  • PHP. 02®. Ajax异步处理、常见的响应状态、XMLHttpRequest对象及API、ajax的get/post方法、

    异步对象

      a)创建异步对象

      b)设置请求的url等参数

      c)  发送请求

      d)注册时间

      e)在注册的事件中获取返回的内容并修改页面显示的内容

    布尔类型不能直接用echo输出

    常见的响应状态

    Ajax概念

    在浏览器中,我们也能够不刷新页面,通过ajax的方式去获取一些新的内容,类似网页有微博,朋友圈,邮箱

    • 单词解释:

    Asynchronous Javascript And XML(异步JavaScript和XML),

    他并不是凭空出现的新技术,而是对于现有技术的结合:核心是js对象XMLHttpRequest

    XMLHttpRequest

    ajax使用的依旧是HTTP请求,那么让我们来回忆一下一个完整的HTTP请求需要什么

    >

    • 请求的网址,方法get/post

    • 提交请求内容数据,请求主体

    • 接收响应回来的内容

    • 五步使用法:

      1. 建立XMLHTTPRequest对象 

      2. 注册回调函数

        • 当服务器回应我们了,我们想要执行什么逻辑 
      3. 使用open方法设置和服务器端交互的基本信息

        • 设置提交的网址,数据,post提交的一些额外内容
      4. 设置发送的数据,开始和服务器端交互

        • 发送数据
      5. 更新界面

        • 在注册的回调函数中,获取返回的数据,更新界面

     XMLHttpRequest_API讲解

    1.创建XMLHttpRequest对象(兼容性写法)

    • 新版本浏览器:
    var xml=new XMLHttpRequest();
    
    • (IE5 和 IE6)
    var xml=new ActiveXObject("Microsoft.XMLHTTP");
    
    • 考虑兼容性创建Ajax对象
     var request ;
     if(XMLHttpRequest){
        // 新式浏览器写法
        request = new XMLHttpRequest();
     }else{
        //IE5,IE6写法
        request = new ActiveXObject("Microsoft.XMLHTTP");
     }

    2.发送请求:

    
    
    方法描述
    open(method,url,async)

    规定请求的类型、URL 以及是否异步处理请求。

      • method:请求的类型;GET 或 POST
      • url:文件在服务器上的位置
      • async:true(异步)或 false(同步)
    send(string)

    将请求发送到服务器。

      • string:仅用于 POST 请求
     

    3.POST请求注意点:

    
    

    如果想要像form表单提交数据那样使用POST请求,需要使用XMLHttpRequest对象的setRequestHeader()方法 来添加 HTTP 头。然后在 send() 方法中添加想要发送的数据:

    xmlhttp.open("POST","ajax_test.php",true);
    
    xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    
    xmlhttp.send("fname=Bill&lname=Gates");

    4.onreadystatechange事件

    当服务器给予我们反馈时,我们需要实现一些逻辑 

    属性描述
    onreadystatechange 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。
    readyState

    存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

      • 0: 请求未初始化
      • 1: 服务器连接已建立
      • 2: 请求已接收
      • 3: 请求处理中
      • 4: 请求已完成,且响应已就绪
    status

    200: "OK"

    404: 未找到页面

    
    
    

    4.服务器响应内容

    如果响应的是普通字符串,使用responseText,如果响应的是XML,使用responseXML

     
    属性描述
    responseText 获得字符串形式的响应数据。
    responseXML 获得 XML 形式的响应数据。
    • 示例代码:GET

        get的数据,直接在请求的url中添加即可

    <script type="text/javascript">
        // 创建XMLHttpRequest 对象
        var xml = new XMLHttpRequest();
        // 设置跟服务端交互的信息
        xml.open('get','01.ajax.php?name=fox');
        xml.send(null);    // get请求这里写null即可
        // 接收服务器反馈
        xhr.onreadystatechange = function () {
            // 这步为判断服务器是否正确响应
            if (xhr.readyState == 4 && xhr.status == 200) {
                // 打印响应内容
                alert(xml.responseText);
            } 
        };
    </script>
    • 示例代码:POST
    <script type="text/javascript">
        // 异步对象
        var xhr = new XMLHttpRequest();
        // 设置属性
        xhr.open('post', '02.post.php' );
        // 如果想要使用post提交数据,必须添加
        xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
        // 将数据通过send方法传递
        xhr.send('name=fox&age=18');
        // 发送并接受返回值
        xhr.onreadystatechange = function () {
        // 这步为判断服务器是否正确响应
        if (xhr.readyState == 4 && xhr.status == 200) {
               alert(xhr.responseText);
             } 
        };
    </script>
  • 相关阅读:
    mysql 按某属性分组,再统计不同状态 COUNT(IF(FIELD(column_name,str1,str2,str3,...) >= 0, any_value, null)) ... GROUP BY group_column_name
    linux shell相关 & 定时清除日志脚本
    Linux exec source
    mybatis关联查询xml文件简写,复用BaseResultMap和sql
    mysql 组内排序(分组之前排序,如分组取最新时间的数据)
    Spring 拦截器postHandle无法修改Response响应头跨域
    产业数据三级联动,直接通过sql查询,开启二级缓存
    MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk
    jd-gui反编译报错 INTERNAL ERROR
    javax.websocket.server.ServerContainer not available
  • 原文地址:https://www.cnblogs.com/mingm/p/6884222.html
Copyright © 2011-2022 走看看