欢迎来到小居数码网-一家分享数码知识,生活小常识的网站,希望可以帮助到您。

当前位置:生活小常识 > 数码知识 >
优质

后端接收json数据(前后端交互的方式ajax)

数码知识

林溟又优秀作者

原创内容 来源:小居数码网 时间:2024-08-07 21:20:01 阅读() 收藏:46 分享:60

导读:您正在阅读的是关于【数码知识】的问题,本文由科普作家协会,生活小能手,著名生活达人等整理监督编写。本文有966个文字,大小约为4KB,预计阅读时间3分钟。

有很多框架已经将 ajax 封装,需要的时候只需要调用就好,比如 jquery 是最常用的。我们为什么还需要学习 ajax 的封装呢?首先加强我们对ajax的认识,其次如果只是因为ajax请求需要引入框架,我们可以自己封装一个,这样就不需要引入多余的框架了。

前后端交互的方式ajax

一、封装的注意点

封装是为了把相同的部分都实现公用,节省资源,提高代码复用性,工作效率也高,所以需要把不同的参数事件类型等通过调用的时候传入,需要注意点有:

1.1、传参

发送 ajax 请求时,主要参数有:

  • 请求url
  • 请求类型
  • 请求参数
  • 成功回调
  • 失败回调
  • 超时时间
  • 以上六个参数必须设置成动态传入的,便于控制任意 ajax 请求。超时时间可以统一设置,如果作为传参可以更方便地控制任意一个请求超时。

    1.2、请求类型分别处理

    请求类型有 get 和 post 两种,get类型传值的时候,数据跟在url地址后,post传值时在请求体内携带,还需设置请求数据类型。所以需要判断分别处理。

    if(type == 'GET'){ xhr.open( 'GET' , url+'?'+strData , true ) shr.send()}else{ xhr.open('POST',url,true) xhr.setRequestHeader('content-type','application/x-www-form-urlencoded') xhr.send( strData )}

    1.3、请求超时处理

    网络服务异常或者接口异常的时候,请求发送出去没有响应,页面也不会做出任何反应,需要全局加一个超时处理,超出时间还没有返回时,自动结束请求,返回异常。

    使用语法如下:

    //设置时间为2sxhr.timeout = 2000 ;//超时回调xhr.ontimeout = function(){ console.log('网络异常,稍后重试')}

    1.4、错误处理

    网络中断,请求无法发送到服务器时,需要对请求失败进行处理。使用onerror事件处理。

    使用语法如下:

    xhr.onerror = function(){ console.log("网络异常,请检查网络")}

    二、封装 ajax 代码

    根据ajax的请求流程,封装代码如下:便于以后使用,建议收藏。

    function ajax(option) { // method, url, data, timeout, success, error var xhr; var str = data2str(option.data); if (window.XMLHttpRequest) {  xhr = new XMLHttpRequest(); }else {  xhr = new ActiveXObject("Microsoft.XMLHTTP"); } if (option.type.toLowerCase() === 'post') {  xhr.open(option.type, option.url, true);   xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");   xhr.send(str);  } else if (option.type.toLowerCase() === 'get') {   xhr.open(option.type, option.url + '?' + str, true);   xhr.send();  } xhr.onreadystatechange = function () {  if (xhr.readyState === 4) {   clearTimeout(timer);   if (xhr.status >= 200 && xhr.status < 300 || xhr === 304) {    option.success(xhr);   }else {    option.error(xhr);   }  } }; if (option.timeout) {  var timer = setTimeout(function () {   xhr.abort();   clearTimeout(timer);  }, option.timeout) }}// 将对象转化成用于传输的字符串function data2str(data) { var res = []; data.t = new Date().getTime(); for (var key in data) {  res.push(encodeURIComponent(key) + '=' + encodeURIComponent(data[key])); } return res.join('&');}

    使用的时候调用代码如下:

    ajax({  method:'GET',  url:'1.txt',  data:{   //请求数据  },  timeout:2000,  success:(res)=>{   console.log('成功返回',res.response)  },  error: err => {   console.log('错误信息',err)  } })

    上面就是小居数码小编今天给大家介绍的关于(前后端交互的方式ajax)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。

    94%的朋友还想知道的:

    (371)个朋友认为回复得到帮助。

    部分文章信息来源于以及网友投稿,转载请说明出处。

    本文标题:后端接收json数据(前后端交互的方式ajax):http://sjzlt.cn/shuma/153528.html

    猜你喜欢