fetch 使用(随笔)

fetch 使用(随笔)

这是我自己使用,封装的fetch使用,包括get/post/文件上传,随手记一下,以防忘记。

 /**
  * fatch
  * @params:请求参数
  * url 请求接口
  * obj 请求数据(post)
  * params 文件(图片上传,formdata)
  * vm  vue实例
  * 使用方法:
  * 引入 import fetchR from '@/assets/javascripts/fetchAsync';
  * get  : fetchR.getFatch(url,vm).then().catch()
  * post : fetchR.postFatch(url, obj, vm).then().catch()
  * img upload : fetchR.uploadFile(url, params,vm).then().catch()
  */
 import conf from '@/assets/pubConf';
 import vm from '@/main'

 export default class FetchAsync {
     // get方法
     static getFatch(url) {
         let geturl = url;
         return new Promise((resolve, reject) => {
                 var url = conf.serverIp + geturl;
                 /*var headers = new Headers();
                 headers.append('Accept', 'application/json');
                 headers.append('Content-Type', 'application/json');
                 headers.append('Token', localStorage.getItem('token'));*/
                 fetch(url, {
                     method: 'GET',
                     headers: {
                         'Accept': 'application/json',
                         'Content-Type': 'application/json',
                         // "Content-Type": "application/json;charset=utf-8",
                         'Token': localStorage.getItem('token')
                     }
                 }).then((response) => {
                     if (response.ok) {
                         return response.json();
                     } else {
                         reject({status: response.status})
                     }
                 }).then((res) => {
                     if (res.status == 403) {
                         vm.$toast('登录信息已过期,请重新登录');
                         vm.$router.push('/');
                     } else {
                         resolve(res)
                     }
                 }).catch((err) => {
                     console.log(err);
                     reject(err)
                 })
             }
         )
     }

     // post方法
     static postFatch(url, params) {
         var url = conf.serverIp + url;
         return new Promise((resolve, reject) => {
                 fetch(url, {
                     method: 'POST',
                     headers: {
                         "Content-Type": "application/json;charset=utf-8",
                         'Token': localStorage.getItem('token')
                     },
                     body: JSON.stringify(params)
                 }).then(response => response.json()).then((res) => {
                     if (res.status == 403) {
                         vm.$toast('登录信息已过期,请重新登录');
                         vm.$router.push('/');
                     } else {
                         resolve(res)
                     }
                 }).catch((err) => {
                     reject(err)
                 });
             }
         )
     }

     // upload file
     static uploadFile(url, params) {
         console.log(params);
         var url = conf.serverIp + url;
         return new Promise((resolve, reject) => {
                 fetch(url, {
                     method: 'POST',
                     headers: {
                         'Token': localStorage.getItem('token')
                     },
                     body: params
                 }).then(response => response.json()).then((res) => {
                     if (res.status == 403) {
                         vm.$toast('登录信息已过期,请重新登录');
                         vm.$router.push('/');
                     } else {
                         resolve(res)
                     }
                 }).catch((err) => {
                     reject(err)
                 });
             }
         )
     }
 }
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值