封装Ajax函数

在这里插入图片描述

Ajax

说道ajax到底什么是ajax? ajax是一种创建交互网页应用的一门技术。
ajax的应用场景有:(地图)实时更新,表单验证等等....
所以要再次结合promise对Ajax进行封装以便于项目开发

ajax请求函数模块

返回值: promise对象(异步返回的数据是: response.data)
 */
import axios from 'axios'
export default function ajax(url, data = {}, type = 'GET') {

    return new Promise(function(resolve, reject) {
        // 执行异步ajax请求
        let promise
        if (type === 'GET') {
            // 准备url query参数数据
            let dataStr = '' //数据拼接字符串
            Object.keys(data).forEach(key => {
                dataStr += key + '=' + data[key] + '&'
            })
            if (dataStr !== '') {
                dataStr = dataStr.substring(0, dataStr.lastIndexOf('&'))
                url = url + '?' + dataStr
            }
            // 发送get请求
            promise = axios.get(url)
        } else {
            // 发送post请求
            promise = axios.post(url, data)
        }
        promise.then(function(response) {
            // 成功了调用resolve()
            resolve(response.data)
        }).catch(function(error) {
            //失败了调用reject()
            reject(error)
        })
    })
}
项目中使用
import ajax from './ajax'
//1.获取位置
export const reqAddress = (geohash) => ajax(`${BASE_URL}/position/${geohash}`);

//2.获取食品分类列表](#2获取食品分类列表)
export const reqFoodCategorys = () => ajax(BASE_URL + '/index_category');

//3.根据经纬度获取商铺列表](#3根据经纬度获取商铺列表)
export const reqShops = (longitude, latitude) => ajax(BASE_URL + '/shops', { longitude, latitude });
//这样就可以愉快的使用封装好的Ajax了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值