博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
封装及调用fetch
阅读量:5099 次
发布时间:2019-06-13

本文共 1694 字,大约阅读时间需要 5 分钟。

一、封装fetch

创建fetch/index.js

import 'whatwg-fetch'import 'es6-promise'export function get(url) {    let result = fetch(url, {        credentials: 'include',        headers: {            'Access-Control-Allow-Origin': '*',            'Accept': 'application/json, text/plain, */*'        },        // 设置允许cors跨域        mode: 'cors'    });    return result;}// 将对象拼接成 key1=val1&key2=val2&key3=val3 的字符串形式function obj2params(obj) {    let result = '';    let item;    for (item in obj) {        result += '&' + item + '=' + encodeURIComponent(obj[item]);    }        if (result) {        result = result.slice(1);    }        return result;}// 发送 post 请求export function post(url, paramsObj) {    let result = fetch(url, {        method: 'POST',        credentials: 'include',        headers: {            'Accept': 'application/json, text/plain, */*',            'Content-Type': 'application/x-www-form-urlencoded'        },        body: obj2params(paramsObj)    });        return result;}

二、调用fetch

1、使用then

import {get} from '../fetch/index';get("./mock/list.json").then((res) => {            return res.json();        }).then((json)=>{            this.setState({                dataList: json.data            })        }).catch(function (err) {            console.log(err);        })

  

二、async、await

import {get} from '../fetch/index';let login = async () => {         try {            let json = await post("#", {             password: password,             username: username           });           let data = await json.json();           console.log(data);         } catch (err) {           console.log(err)         }       }       login()

  

转载于:https://www.cnblogs.com/detanx/p/fetchQ2.html

你可能感兴趣的文章
用Chrome调试Android手机上的网页
查看>>
django 王中王8之踏青撒花
查看>>
学习网站收集
查看>>
linux命令
查看>>
类库与框架,强类型与弱类型的闲聊
查看>>
webView添加头视图
查看>>
字符环(openjudge 2755)
查看>>
php match_model的简单使用
查看>>
在NT中直接访问物理内存
查看>>
Intel HEX 文件格式
查看>>
SIP服务器性能测试工具SIPp使用指导(转)
查看>>
Centos Development Tools 安装
查看>>
vue form 验证
查看>>
php_扑克类
查看>>
回调没用,加上iframe提交表单
查看>>
socket总结
查看>>
(安卓)一般安卓开始界面 Loding 跳转 实例 ---亲测!
查看>>
元素和为目标值的子矩阵数量
查看>>
POJ-1287.Network(Kruskal + Prim + Prim堆优化)
查看>>
Mysql 索引优化 - 1
查看>>