请求后台接口的方式有什么?有什么区别

  昨天被头条的面试官面完之后虐了一地,倒是不难,问一堆这个和那个有啥不同,我心里想着难道有可比性么,这种问题怎么感觉就像有时候问你人都有什么人?有啥不同一样。。。只能吐槽但是也无能为力,就怪自己学艺不精吧。

  当时可能是面试官太帅了,所以太紧张了,我竟然脑子里面想不起来原生是怎么写的了,直接说把原生的忘了,xmlhttpRequest在我的脑海里竟然一点映象也没了,面之前还手写的代码。。。

请求接口除了原生ajax,$.ajax,fetch,axios,vue框架的话自己也封装了一个vuereaouce方法。先看看这几个请求接口的写法:

原生的请求方法:

var xhr = new xmlHttpRequest();

var httprequest

xhr.onreadystatechange = function(){

if(httpRequest.readyState === XMLHttpRequest.DONE){

  if (httpRequest.status === 200) {

   alert(httpRequest.responseText);

  } else {

  alert('There was a problem with the request.');

  }

  }

  httpRequest.open('GET',url);

//发送请求

  httpRequest.send();

}

原生的ajax请求经历了这四部:

1.创建一个xmlhttpRequest请求

2.指定响应函数

3.发送请求

基于原生的ajax,大神们进行封装净化到了jquery的$.ajax,$.ajax如果用到现在的mvvm框架里面就有点不搭了,显得项目有点大占内存,配置和调用不友好

$.ajax({
   type: 'POST',
   url: url,
   data: data, dataType: dataType, success: function () {}, error: function () {} });
自从2016年开始流行es6之后,fetxh和axios开始盛行了
axios:
  1.从浏览器中创建 XMLHttpRequest
  2.支持 Promise API
  3.客户端支持防止CSRF
  4.提供了一些并发请求的接口(重要,方便了很多的操作)
  5.从 node.js 创建 http 请求
  6.拦截请求和响应
  7.转换请求和响应数据
  8.取消请求
  9.自动转换JSON数据
axios({
   method: 'post',
  url: '/axios/ajax',
  data: {
      } })
     .then(function (response) { console.log(response); })
     . catch(function (error) { console.log(error);
  });
axios相对于别的请求接口方法里面是相对于处理的比较好的,也比较常用
fetch的写法
fetch(url,parame,callback).then(respose.json()).then(data=>console.log(data)).catch(err =>console.log(err))
下面这部分是博主的一些内容:

Ajax:
       ajax,最早出现的发送后端请求技术,隶属于原始js中,核心使用XMLHttpRequest对象,多个请求之间如果有先后关系的话,就会出现回调地狱。
Jquery Ajax:
      是jQuery框架中的发送后端请求技术,由于jQuery是基于原始的基础上做的封装,所以,jquery Ajax自然也是对原始ajax的封装
Fetch:
     fetch号称是AJAX的替代品,是在ES6出现的,使用了ES6中的promise对象。Fetch是基于promise设计的。Fetch的代码结构比起ajax简单多了,参数有点像jQuery ajax。但是,一定记住fetch不是ajax的进一步封装,而是原生js。Fetch函数就是原生js,没有使用XMLHttpRequest对象。
axios:

     axios不是原生JS的,需要进行安装,它不但可以在客户端使用,而且可以在nodejs端使用。Axios也可以在请求和响应阶段进行拦截。同样也是基于promise对象的。



 

转载于:https://www.cnblogs.com/smdb/p/10196216.html

### 回答1: 在 JavaScript 中,可以使用 XMLHttpRequest 对象或 Fetch API 来发送 HTTP 请求并获取响应结果。以下是使用 XMLHttpRequest 对象的示例代码: ```javascript const xhr = new XMLHttpRequest(); xhr.open('GET', 'https://example.com/api/data'); xhr.onload = function() { if (xhr.status === 200) { const data = JSON.parse(xhr.responseText); console.log(data); } else { console.error('请求失败:' + xhr.statusText); } }; xhr.onerror = function() { console.error('请求失败:网络错误'); }; xhr.send(); ``` 除了 GET 请求,还可以使用 POST、PUT、DELETE 等方法来发送请求,需要根据接口要求设置相应的请求头和请求体。 使用 Fetch API 的示例代码如下: ```javascript fetch('https://example.com/api/data') .then(response => { if (response.ok) { return response.json(); } else { throw new Error('请求失败:' + response.statusText); } }) .then(data => console.log(data)) .catch(error => console.error(error)); ``` Fetch API 的优点是使用 Promise 对象来处理异步操作,代码更简洁易读。 ### 回答2: 当我们在JavaScript中发送请求到一个接口时,我们会希望接口返回我们需要的结果。但是,如果我们收到的结果是"????",那么可能有以下几种情况造成这种情况发生。 1. 错误的接口地址:首先,我们需要确保我们发送请求接口地址是正确的。如果地址错误或者拼写错误,服务器将无法找到相应的接口,导致返回的结果是"????"。 2. 接口无法访问:有时候,接口可能由于某种原因无法访问,例如服务器故障、网络问题等。如果接口无法访问,我们可以得到的结果可能只是一个错误提示或者"????"。 3. 请求参数错误:如果我们发送的请求参数不符合接口的要求,服务器可能无法正确处理请求,导致返回结果是"????"。我们需要检查请求参数的数据类型、格式是否正确。 4. 接口返回错误:接口可能存在bug或者逻辑错误,导致返回的结果不符合预期。这种情况下,我们无法直接确定具体问题所在,需要与接口开发人员进行沟通,以便修复问题。 为了解决以上问题,我们可以采取以下措施: 1. 检查接口地址是否正确。 2. 确保接口可访问性,可以尝试在浏览器中直接访问接口地址,查看返回结果。 3. 检查请求参数是否正确,可以使用调试工具或者打印日志查看请求参数的数据类型、格式是否正确。 4. 与接口开发人员进行沟通,报告问题,以便修复。 总之,"????"这种结果可能是由于接口地址错误、接口无法访问、请求参数错误或者接口返回错误所导致。我们需要仔细检查和排除这些问题,以获得正确的接口返回结果。 ### 回答3: 对于JavaScript(简称JS)请求接口后返回的结果,需要根据具体的接口请求方式进行分析。 通常情况下,JS通过各种请求方法(如GET、POST等)向后台发送请求后台会处理请求,并返回相应的结果给前端。这个返回的结果可以包含多种形式的数据,如文本、JSON、XML等。 如果接口请求成功,前端JS代码可以通过回调函数或者Promise来处理返回的结果。例如,如果请求的结果是以JSON形式返回,可以使用`res.json()`方法将返回的数据转化为JavaScript对象进行进一步处理。 在请求接口时,有时候会遇到不同的响应状态码。常见的有200表示请求成功,404表示请求的资源不存在,500表示服务器内部错误等等。根据不同的状态码,前端可以采取不同的处理逻辑。 在处理请求结果时,还需要注意异常处理。如果请求过程中遇到网络错误、接口超时等问题,可以通过错误处理的方法来捕获异常并进行相应的处理,比如显示特定的错误提示信息。 综上所述,JS请求接口后返回的结果应该根据具体情况来处理,包括解析返回数据的格式、处理状态码和异常处理等。通过合理的处理逻辑,前端可以有效地利用接口返回的结果,实现更加丰富和交互性的前端应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值