zoukankan      html  css  js  c++  java
  • uniapp的ajax封装请求

    uniapp的ajax封装请求

    const baseUrl = 'http://172.16.10.5:8802';
    const httpRequest = (opts, data) => {
        let httpDefaultOpts = {
            url: baseUrl + opts.url,
            data: data,
            method: opts.method,
            header: opts.method == 'get' ? {
                'X-Requested-With': 'XMLHttpRequest',
                "Accept": "application/json",
                "Content-Type": "application/json; charset=UTF-8"
            } : {
                'X-Requested-With': 'XMLHttpRequest',
                "Content-Type": "application/json; charset=UTF-8"
                // 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
            },
            dataType: 'json',
        }
        let promise = new Promise(function(resolve, reject) {
            uni.request(httpDefaultOpts).then(
                (res) => {
                    resolve(res[1])
                }
            ).catch(
                (response) => {
                    reject(response)
                }
            )
        })
        return promise
    };
    //带Token请求
    const httpTokenRequest = (opts, data) => {
        let token = uni.getStorageSync('userToken');
        uni.getStorage({
            key: 'token',
            success: function(ress) {
                token = ress.data
            }
        });
        //此token是登录成功后后台返回保存在storage中的
        let httpDefaultOpts = {
            url: baseUrl + opts.url,
            data: data,
            method: opts.method,
            header: opts.method == 'get' ? {
                'Authorization': token,
                'X-Requested-With': 'XMLHttpRequest',
                "Accept": "application/json",
                "Content-Type": "application/json; charset=UTF-8"
                // "Content-Type": "application/json; charset=UTF-8"
            } : {
                'Authorization': token,
                'X-Requested-With': 'XMLHttpRequest',
                "Content-Type": "application/json; charset=UTF-8"
                // 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
            },
            dataType: 'json',
        }
        let promise = new Promise(function(resolve, reject) {
            uni.request(httpDefaultOpts).then(
                (res) => {
                    // console.log(3333333333333333333,res)
                    resolve(res[1])
                }
            ).catch(
                (response) => {
                    reject(response)
                }
            )
        })
        return promise
    };
    
    export default {
        baseUrl,
        httpRequest,
        httpTokenRequest
    }

    组件使用

    //引入组件
        import http from '@/common/api/api.js'
    //使用方法
            // 详情页页面
                getDetials() {
                    let opts = {
                        url: '/applet/findDeviceId',
                        method: 'get'
                    };
                    let param = {
                        deviceName: this.deviceName,
                        openid: this.openid,
                        pageNo: this.pageNo,
                        pageSize: this.pageSize,
                        deviceType: this.deviceType
                    };
                    http.httpRequest(opts, param).then(res => {
                        console.log(res, "2222222");
                        // _this.isRotate = false
                        uni.hideLoading()
                        if (res.data.code == 200) {
                            // console.log(res.data.result)
                            this.current = res.data.result.current
                            this.total = res.data.result.total
                            this.tableList = res.data.result.records
                        } else {
                            uni.showToast({
                                icon: 'none',
                                position: 'bottom',
                                title: res.data.message
                            });
                        }
                    })
                },
  • 相关阅读:
    记一次性能优化经历
    把一个一中的字段更新另一个表中的t-sql
    Dapper 中使用sql in 关键字查询
    HTML5 学习笔记 应用程序缓存
    HTML5学习笔记 Web存储
    HTML5 学习笔记 表单属性
    HTML5学习笔记 Geolocation(地理定位)
    vim插件之delimitMate.vim
    vim 插件之 surround.vim
    vim 脚本之快速打印log
  • 原文地址:https://www.cnblogs.com/ly1368489670/p/13918222.html
Copyright © 2011-2022 走看看