vue请求封装方案

方案一 config/fetch.js

import {
     
	baseUrl
} from './env'

// 封装一个请求函数
export default async(url = '', data = {
     }, type = 'GET', method = 'fetch') => {
     
	type = type.toUpperCase();
	url = baseUrl + url;

	if (type == 'GET') {
     
		let dataStr = ''; //数据拼接字符串
		Object.keys(data).forEach(key => {
     
			dataStr += key + '=' + data[key] + '&';
		})

		if (dataStr !== '') {
     
			dataStr = dataStr.substr(0, dataStr.lastIndexOf('&'));
			url = url + '?' + dataStr;
		}
	}

	if (window.fetch && method == 'fetch') {
     
		let requestConfig = {
     
			credentials: 'include',
			method: type,
			headers: {
     
				'Accept': 'application/json',
				'Content-Type': 'application/json'
			},
			mode: "cors",
			cache: "force-cache"
		}

		if (type == 'POST') {
     
			Object.defineProperty(requestConfig, 'body', {
     
				value: JSON.stringify(data)
			})
		}
		
		try {
     
			const response = await fetch(url, requestConfig);
			const responseJson = await response.json();
			return responseJson
		} catch (error) {
     
			throw new Error(error)
		}
	} else {
     
		return new Promise((resolve, reject) => {
     
			let requestObj;
			if (window.XMLHttpRequest) {
     
				requestObj = new XMLHttpRequest();
			} else {
     
				requestObj = new ActiveXObject;
			}

			let sendData = '';
			if (type == 'POST') {
     
				sendData = JSON.stringify(data);
			}

			requestObj.open(type, url, true);
			requestObj.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
			requestObj.send(sendData);

			requestObj.onreadystatechange = () => {
     
				if (requestObj.readyState == 4) {
     
					if (requestObj.status == 200) {
     
						let obj = requestObj.response
						if (typeof obj !== 'object') {
     
							obj = JSON.parse(obj);
						}
						resolve(obj)
					} else {
     
						reject(requestObj)
					}
				}
			}
		})
	}
}

使用方式:
service/getData.js

import fetch from '../config/fetch'
import {
     getStore} from '../config/mUtils'//在这里是获取缓存数据的函数

export const hotcity = () => fetch('/v1/cities', {
     
	type: 'hot'
});

/**
 * 重新发送订单验证码
 */
export const rePostVerify = (cart_id, sig, type) => fetch('/v1/carts/' + cart_id + '/verify_code', {
     
	sig,
	type,
}, 'POST');
/**
 * 获取用户信息
 */

export const getUser = () => fetch('/v1/user', {
     user_id: getStore('user_id')});
/**
 * 获取首页所有城市
 */

export const groupcity = () => fetch('/v1/cities', {
     
	type: 'group'
});

// async 函数返回一个 Promise 对象,可以使用 then 方法添加回调函数。当函数执行的时候,一旦遇到 await 就会先返回,等到触发的异步操作完成,再接着执行函数体内后面的语句。
所以

//获取所有城市
 groupcity().then(res => {
     
     this.groupcity = res;
 })

或者:

  async initData(){
     
                if (this.userInfo && this.userInfo.user_id) {
     
                    this.orderData = await getOrderDetail(this.userInfo.user_id, this.orderDetail.unique_id);
                    this.showLoading = false;
                    this.$nextTick(() => {
     
                        new BScroll('#scroll_section', {
       
                            deceleration: 0.001,
                            bounce: true,
                            swipeTime: 1800,
                            click: true,
                        }); 
                    })
                }
            },

方案二

你可能感兴趣的:(vue,请求封装,axios,fetch,async,await)