ES6的Fetch异步请求的实现方法


Posted in Javascript onDecember 07, 2018

在前端的快速发展中,为了契合更好的设计模式,产生了Fetch框架,Fetch返回的信息比XMLHttpRequest更丰富。但它目前还不是一个标准,它支持大部分常用的http 请求和响应的标准。

一. 一个完整的post请求和响应的过程

var url = "/fetch";
     fetch(url,{
       method:"post",
       headers:{
         "Content-type":"application/x-www-form-urlencoded"
       },
       body:"name=luwenjing&age=22"
     })
      .then(function (response){
        if (response.status == 200){
          return response;
        }
      })
      .then(function (data) {
       return data.text();
      })
      .then(function(text){
        console.log("请求成功,响应数据为:",text);
      })
      .catch(function(err){
        console.log("Fetch错误:"+err);
      });

(1)fetch的参数有两个,第一个是url即请求的处理路径;

第二个是初始化信息,包括以下几种:

  • method:请求方法,常用的有get和post;
  • headers:请求头信息,最常用的就是表单格式的数据:”Content-type”:”application/x-www-form-urlencoded”;
  • mode:控制是否允许跨域。same-origin(同源请求)、no-cors(默认)和cros(允许跨域请求);
  • cache:关于缓存的一些设置;
  • body:要发送到后台的参数,可以为ArrayBuffer,String,FormData等类型;

(2)从上面的代码我们可以知道fetch()方法返回的是一个promise对象;

(3)响应信息为传入then方法成功时的参数,相应包含很多http的响应信息,如下:

ES6的Fetch异步请求的实现方法

(4)可以判断响应的状态吗,返回请求成功的对应信息;

(5)通过状态转换,转换为指定的格式,如果是文本信息,直接text()方法就可以;若为json格式,则json()就可以转换为json格式信息,其实也就是自己请求数据格式时所设置的格式;

二. 后台处理代码:

import java.io.IOException;
import java.io.Writer;

/**
 * Created by LuWenjing on 2017/4/5.
 */
public class fetchServlet extends javax.servlet.http.HttpServlet {
  protected void doPost(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
    String name = request.getParameter("name");
    String age = request.getParameter("age");
    System.out.println(name + ": " + age);
    Writer out = response.getWriter();
    out.write("hello world!");
  }

  protected void doGet(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
    doPost(request, response);
  }
}

后台成功输出:ES6的Fetch异步请求的实现方法

浏览器控制台成功打印:ES6的Fetch异步请求的实现方法

三. 和ajax 的对比

(1)上面的Fetch代码很像jQuery中的ajax,但是两者是不同的,fetch是原生的js,而jQuery中的ajax是库封装的;

(2)ajax只能实现同源请求,fetch可实现跨域请求;

(3)ajax几乎所有的主流浏览器都支持,但fetch由于目前并没有被列入标准,只有像firefox最新版,chrome最新版,以及IE10+等以上才支持,如下图片所示;

ES6的Fetch异步请求的实现方法

注意:在body中向后台传递参数时,只有写成“key=value&key=value”的形式才会成功,其它方法后台接收到均为null,封装为FormData格式也不成功。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JSP中使用JavaScript动态插入删除输入框实现代码
Jun 13 Javascript
js实现网页右上角滑出会自动消失大幅广告的方法
Feb 27 Javascript
jQuery插件Skippr实现焦点图幻灯片特效
Apr 12 Javascript
详解JavaScript基于面向对象之创建对象(1)
Dec 10 Javascript
JSP基于Bootstrap分页显示实例解析
Jun 12 Javascript
vue2 router 动态传参,多个参数的实例
Nov 10 Javascript
对vuejs的v-for遍历、v-bind动态改变值、v-if进行判断的实例讲解
Aug 27 Javascript
支付宝小程序自定义弹窗dialog插件的实现代码
Nov 30 Javascript
VUE兄弟组件传值操作实例分析
Oct 26 Javascript
微信小程序开发(三):返回上一级页面并刷新操作示例【页面栈】
Jun 01 Javascript
vue-cli4.x创建企业级项目的方法步骤
Jun 18 Javascript
JavaScript中跨域问题的深入理解
Mar 04 Javascript
JavaScript this绑定过程深入详解
Dec 07 #Javascript
React 使用recharts实现散点地图的示例代码
Dec 07 #Javascript
如何手动实现es5中的bind方法详解
Dec 07 #Javascript
JavaScript时间与时间戳的转换操作实例分析
Dec 07 #Javascript
vue+SSM实现验证码功能
Dec 07 #Javascript
详解如何为你的angular app构建一个第三方库
Dec 07 #Javascript
JS实现随机生成10个手机号的方法示例
Dec 07 #Javascript
You might like
PHP中的插件机制原理和实例
2014/07/08 PHP
PHP使用mysqldump命令导出数据库
2015/04/14 PHP
PHP静态延迟绑定和普通静态效率的对比
2017/10/20 PHP
js常见表单应用技巧
2008/01/09 Javascript
node.js中的fs.readlink方法使用说明
2014/12/17 Javascript
纯javascript实现四方向文本无缝滚动效果
2015/06/16 Javascript
jQuery zclip插件实现跨浏览器复制功能
2015/11/02 Javascript
微信小程序 获取微信OpenId详解及实例代码
2016/10/31 Javascript
JavaScript中的遍历详解(多种遍历)
2017/04/07 Javascript
vue.js路由跳转详解
2017/08/28 Javascript
浅谈Angular 观察者模式理解
2018/11/01 Javascript
详解vue-router导航守卫
2019/01/19 Javascript
浅谈Matplotlib简介和pyplot的简单使用——文本标注和箭头
2018/01/09 Python
Python使用pyautocad+openpyxl处理cad文件示例
2019/07/11 Python
python 函数的缺省参数使用注意事项分析
2019/09/17 Python
numpy.transpose()实现数组的转置例子
2019/12/02 Python
Python类反射机制使用实例解析
2019/12/30 Python
python下载卫星云图合成gif的方法示例
2020/02/18 Python
python实现无边框进度条的实例代码
2020/12/30 Python
CSS3解析抖音LOGO制作的方法步骤
2019/04/11 HTML / CSS
怀旧收藏品和经典纪念品:Betty’s Attic
2018/08/29 全球购物
英国家喻户晓的家居商店:The Range
2019/03/25 全球购物
Puccini乌克兰:购买行李箱、女士手袋网上商店
2020/08/06 全球购物
普通大学毕业生自荐信
2013/11/04 职场文书
研发工程师的岗位职责
2013/11/18 职场文书
计算机应用专业应届毕业生中文求职信范文
2013/11/29 职场文书
财务主管自我鉴定
2014/01/17 职场文书
电气工程自动化求职信
2014/03/14 职场文书
关于青春的演讲稿
2014/05/05 职场文书
员工保密承诺书
2014/05/28 职场文书
公务员上班玩游戏检讨书
2014/09/17 职场文书
司考复习计划
2015/01/19 职场文书
陪护人员误工证明
2015/06/24 职场文书
建立共青团委员会的请示
2019/04/02 职场文书
七年级话题作文之执着
2019/11/19 职场文书
Redis Cluster 集群搭建你会吗
2021/08/04 Redis