加入收藏 | 设为首页 | 会员中心 | 我要投稿 衡阳站长网 (https://www.0734zz.cn/)- 数据集成、设备管理、备份、数据加密、智能搜索!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

全面分析前端的网络请求方式

发布时间:2019-03-29 02:32:12 所属栏目:优化 来源:ConardLi
导读:一、前端进行网络请求的关注点 大多数情况下,在前端发起一个网络请求我们只需关注下面几点: 传入基本参数(url,请求方式) 请求参数、请求参数类型 设置请求头 获取响应的方式 获取响应头、响应状态、响应结果 异常处理 携带cookie设置 跨域请求 二、前

用于初始化一个请求,用法:

  1. xhr.open(method, url, async); 
  • method:请求方式,如get、post
  • url:请求的url
  • async:是否为异步请求

send

用于发送 HTTP 请求,即调用该方法后HTTP请求才会被真正发出,用法:

  1. xhr.send(param) 
  • param:http请求的参数,可以为string、Blob等类型。

abort

用于终止一个ajax请求,调用此方法后readyState将被设置为0,用法:

  1. xhr.abort() 

setRequestHeader

用于设置HTTP请求头,此方法必须在 open() 方法和 send() 之间调用,用法:

  1. xhr.setRequestHeader(header, value); 

getResponseHeader

用于获取http返回头,如果在返回头中有多个一样的名称,那么返回的值就会是用逗号和空格将值分隔的字符串,用法:

var header = xhr.getResponseHeader(name);

属性

readyState

用来标识当前XMLHttpRequest对象所处的状态,XMLHttpRequest对象总是位于下列状态中的一个:

status

表示http请求的状态, 初始值为0。如果服务器没有显式地指定状态码, 那么status将被设置为默认值, 即200。

responseType

表示响应的数据类型,并允许我们手动设置,如果为空,默认为text类型,可以有下面的取值:

response

返回响应的正文,返回的类型由上面的responseType决定。

withCredentials

ajax请求默认会携带同源请求的cookie,而跨域请求则不会携带cookie,设置xhr的withCredentials的属性为true将允许携带跨域cookie。

事件回调

onreadystatechange

  1. xhr.onreadystatechange = callback; 

当readyState 属性发生变化时,callback会被触发。

onloadstart

  1. xhr.onloadstart = callback; 

在ajax请求发送之前(readyState==1后, readyState==2前),callback会被触发。

onprogress

  1. xhr.onprogress = function(event){  
  2.   console.log(event.loaded / event.total);  
  3. }  

回调函数可以获取资源总大小total,已经加载的资源大小loaded,用这两个值可以计算加载进度。

onload

  1. xhr.onload = callback; 

当一个资源及其依赖资源已完成加载时,将触发callback,通常我们会在onload事件中处理返回值。

异常处理

onerror

  1. xhr.onerror = callback; 

当ajax资源加载失败时会触发callback。

ontimeout

  1. xhr.ontimeout = callback; 

当进度由于预定时间到期而终止时,会触发callback,超时时间可使用timeout属性进行设置。

六、jQuery对Ajax的封装

在很长一段时间里,人们使用jQuery提供的ajax封装进行网络请求,包括$.ajax、$.get、$.post等,这几个方法放到现在,我依然觉得很实用。

  1. $.ajax({  
  2.     dataType: 'json', // 设置返回值类型  
  3.     contentType: 'application/json', // 设置参数类型  
  4.     headers: {'Content-Type','application/json'},// 设置请求头  
  5.     xhrFields: { withCredentials: true }, // 跨域携带cookie  
  6.     data: JSON.stringify({a: [{b:1, a:1}]}), // 传递参数  
  7.     error:function(xhr,status){  // 错误处理  
  8.        console.log(xhr,status);  
  9.     },  
  10.     success: function (data,status) {  // 获取结果  
  11.        console.log(data,status);  
  12.     }  
  13. })  

$.ajax只接收一个参数,这个参数接收一系列配置,其自己封装了一个jqXHR对象,有兴趣可以阅读一下jQuary-ajax 源码

常用配置:

url

当前页地址。发送请求的地址。

type

类型:String 请求方式 ("POST" 或 "GET"), 默认为 "GET"。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。

timeout

类型:Number 设置请求超时时间(毫秒)。此设置将覆盖全局设置。

success

类型:Function 请求成功后的回调函数。

jsonp

在一个jsonp请求中重写回调函数的名字。这个值用来替代在"callback=?"这种GET或POST请求中URL参数里的"callback"部分。

error 类型:Function 。请求失败时调用此函数。

(编辑:衡阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读