6-js-ajax

什么是AJAX

ajax 即“Asynchronous JavaScript and XML”(异步 JavaScript 和 XML),
也就是无刷新数据读取。

http 请求

首先需要了解 http 请求的方法(GET 和 POST)。

GET 用于获取数据。GET 是在 URL 中传递数据,它的安全性低,容量低。

POST 用于上传数据。POST 安全性一般,容量几乎无限。

ajax 请求

ajax 请求一般分成 4 个步骤。
  1. 创建 ajax 对象

在创建对象时,有兼容问题:

var oAjax = new XMLHttpRequest();   //for ie6 以上
var oAjax = new ActiveXObject('Microsoft.XMLHTTP'); //for ie6

//合并

var oAjax = null;
if(window.XMLHttpRequest){
    oAjax = new XMLHttpRequest();
}else{
    oAjax = new ActiveXObject('Microsoft.XMLHTTP');
}
  1. 连接服务器

在这里会用到 open() 方法。启动一个请求以备发送。open() 方法有三个参数,

  • 第一个参数是连接方法即 GET 和 POST,
  • 第二个参数是 URL 即所要读取数据的地址,
  • 第三个参数是否异步,它是个布尔值,true 为异步,false 为同步。
oAjax.open('GET', url, true);

在open()之后、send()之前可以修改HTTP请求头信息,建议不要改变浏览器默认设置的信息,可以增加
自定义的数据

  ```
    oAjax.setRequestHeader('myId','001');

    //查看responseHeader
    oAjax.getResponseHeader('content-type');
    oAjax.getAllResponseHeaders()
  ```
  1. 发送请求

    send() 方法。

    oAjax.send(null);
    //如果不需要传送数据,则必须放置null。因为部分浏览器要求必须要加null。
    

    如果您希望通过 GET 方法发送信息,请向 URL 添加信息
    但是url加的查询字符串必须使用 encodeURICompent()进行编码才能加入。

                function addURLParam(url,name,value) {
                    url+=(url.indexOf("?")==-1)?"?":"&";
                    url+=encodeURIComponent(name)+"="+encodeURIComponent(value);
                    return url;
                }
    
    • application/x-www-form-urlencoded(大多数请求可用:eg:‘name=Denzel&age=18’)
    • multipart/form-data(文件上传)
    • application/json(json格式对象,eg:{‘name’:‘Denzel’,‘age’:‘18’})
      将请求发送到服务器(后台记得用request.json()哦)。

    string:仅用于 POST 请求

    oAjax.send('fname=Bill&lname=Gates);
    

    如果需要像 HTML 表单那样 POST 数据,请使用 setRequestHeader() 来添加 HTTP 头。
    然后在 send() 方法中规定您希望发送的数据(表单数据封装格式和GET提交数据格式相同):

    oAjax.send($('#myform').serialize());
    
    xmlhttp.open("POST","ajax_test.asp",true);
    xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    xmlhttp.send("fname=Bill&lname=Gates");
    

    send()请求是同步的,意味着后续的js代码必须等到服务器响应之后才继续执行。所以在收到响应后,
    响应的数据会自动填充到XHR对象的属性。

  2. 接收返回值

    XHR对象接受的属性有:

    • responseText
    • responseXML 如果响应的内容类型是"text/xml"或"application/xml",则该属性值为XML DOM文档。
    • status
    • statusText

    onreadystatechange 事件。当请求被发送到服务器时,我们需要执行一些基于响应的任务。
    每当 readyState 改变时,就会触发 onreadystatechange 事件。

    readyState:请求状态,返回的是整数(0-4)。

    0(未初始化):还没有调用 open() 方法。

    1(载入):已调用 send() 方法,正在发送请求。

    2(载入完成):send() 方法完成,已收到全部响应内容。

    3(解析):正在解析响应内容。

    4(完成):响应内容解析完成,可以在客户端调用。

    status:请求结果,返回 200 或者 404。

    200 => 成功。

    304 => 请求的资源并没有被修改,可以直接使用浏览器中缓存的版本。

    404 => 失败。

    responseText:返回内容,即我们所需要读取的数据。需要注意的是:responseText 返回的是字符串。

    oAjax.onreadystatechange=function(){
        if(oAjax.readyState==4){
            if(oAjax.status>=200 && oAjax.status<300 || oAjax.status==304){
                fnSucc(oAjax.responseText);
            }else{
                if(fnFaild){
                    fnFaild();
                }
            }
        }
    };
    

XMLHttpRequest 2

  1. formdata

    var form=$('#myform')[0];
    var formdata=new FormData(form);
    formdata.append('from','lzhan.com');
    formdata.set('from','163.com');
    
    console.log(formdata.get('from'));
    console.log(formdata.get('id'));
    formdata.forEach(function (value,key) {
        console.log(value);
    })
    
  2. 超时设定

    oAjax.timeout=3000;
        oAjax.ontimeout=function () {
    
    };
    
  3. 下载进度事件

    var pro=document.querySelector('#loadProgress');
                    oAjax.function (e) {
                        pro.setAttribute('max',parseInt(e.totalSize));
    
                        if(e.lengthComputable){
                            pro.setAttribute('value',e.position);
    
                        }
                    }
    

    progess事件会在接受数据期间周期性触发。

  4. 跨域

     http://www.163.com
     
     http://www.163.com:80
     
     端口不同
     http://www.163.com:8080
     
     协议不同
     https://www.163.com:80
     
     模块不同
     
     http://news.163.com:80
     
     网址不同
     
     http://www.qq.com:80
    
    
    
    
     flask_cors : https://flask-cors.readthedocs.io/en/latest/
    
  5. 关于token

    XMLHttpRequest对象可以利用header提交token

     oAjax.setRequestHeader('token',token);
    

    服务器端可以通过下面方式接受token

     request.headers['token']
    

    但是、服务器端通过response.headers[‘token’]=token发送给客户端时,XMLHttpRequest对象却无法通过oAjax.getResponseHeader(‘token’)来获取
    所以我们可以通过把token作为数据的一部分来发送给客户端:

     return json.jsonify({"statuscode": "201","token":token.decode()})
    

##get

  1. 请求的方式

    1. 在浏览器地址栏中输入https://www.baidu.com/s?wd=python
    2. <a href=“https://www.baidu.com/s?wd=python”>搜索python
    3. 利用表单
    4. location.href
    5. ajax
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值