欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

分析uniapp如何動態(tài)獲取接口域名

 更新時間:2021年06月07日 09:10:08   作者:點幾  
本文主要介紹了uniapp如何動態(tài)獲取接口域名,感興趣的同學,可以參考下,并且試驗一下。

背景

接口域名沒有寫死,而是動態(tài)獲取。具體實現就是 通過讀取一個靜態(tài)json文件,來設置真實的接口域名。好處是原域名有可能被封,這樣可以直接后臺操作修改該配置文件即可;不然的話,h5 項目可能還好說,app 的話必須重新發(fā)版。

代碼

// httpService.js 對 uni.request 的封裝。

在數據請求入口處,統(tǒng)一先進行 域名獲取,即 執(zhí)行 config.requestRemoteIp 方法

import config from '@/config'
import Vue from 'vue'
import cacheData from '@/service/cacheData.js'
const MockUtil = () => import('@/libs/mockUtil.js')
import Storage from '@/libs/storage.js'

class HttpRequest {

    /**
     * 讀取接口數據
     * @param options 請求信息
     * @param noMock  在整體使用mock數據的情形下,可 單獨設置 某個接口請求真實數據
     * @param cacheId
     * @returns {*}
     */
    async requestResolve(options, urlCustom = '', noMock = false, cacheId = null) {
        let remoteIP = await config.requestRemoteIp(); // 動態(tài)設置接口請求域名
        
        if (process.env.NODE_ENV === 'development' && config.isMockApi && !noMock) {
            return this.getMockData(options)
        }
        if (cacheId && cacheData[cacheId]) {
            return this.testHttp(cacheData[cacheId])
        }
        return new Promise((resolve, reject) => {
            let baseUrl = process.env.NODE_ENV === 'development' ? config.baseUrl.dev : config.baseUrl.pro;
            options.url = baseUrl + options.url + `${urlCustom}`;
            uni.request(
                Object.assign({
                    success: (res) => {
                        if (res.statusCode != '200'){
                            uni.showToast({
                                title: '服務器錯誤:'+res.statusCode,
                                icon: "none"
                            })
                            reject()
                        }
                        else if (res.data.code == 10001) {
                            Storage.removeToken();
                            let vue = new Vue();
                            vue.$store.dispatch('logout')
                            vue.$routeUtil.reLaunch('main');
                        }
                        
                        else if (res.data.code != 200) {
                            if (res.data.message) {
                                uni.showToast({
                                    icon: 'none',
                                    title: res.data.message
                                });
                            }
                            reject(res.data)
                        } else {
                            if (cacheId) {
                                cacheData[cacheId] = res.data.data
                            }
                            resolve(res.data.data)
                        }
                    },
                    fail: err => {
                        uni.showToast({
                            title: '服務器錯誤',
                            icon: "none"
                        })
                    }
                }, options)
            );
        })
    }

    /**
     * mock數據按需導入
     * @param options
     * @returns {*}
     */
    async getMockData(options) {
        const Mock = await MockUtil()
        const MockUrl = Mock.default[options.url]
        if (typeof MockUrl !== 'function') {
            return this.testHttp(MockUrl)
        }
        if (options.method === 'post') {
            return this.testHttp(MockUrl(options.data, false))
        }
        return this.testHttp(MockUrl(options.params, true))
    }
    testHttp(data) {
        let pro = new Promise(function(resolve, reject) {
            setTimeout(function() {
                resolve(data)
            }, 50)
        })
        return pro
    }
}
export default new HttpRequest()

// config.js

const config = {
  isMockApi: false,
  // requestUrl: 'http://qiniu.eightyin.cn/teacherpath.json?time=' + Math.random().toString(36),
  requestUrl: 'http://qiniu.eightyin.cn/teacherpathtest.json?time=' + Math.random().toString(36),
  baseUrl: {
     
    dev: '',
    pro: ''
  },
  img: {
    ossDomain: ''
  },
  uuid: Math.random().toString(36).substring(3, 20),
  requestRemoteIp: () => {
      console.log('config:', config)
      if (config.RemoteIpInited)
        return Promise.resolve();
        return new Promise((resolve, reject) => {
            uni.request({
                url: config.requestUrl,
                success: (response) => {
                    //todo 測試
                    // config.baseUrl.pro = response.data.data.path;
                    config.baseUrl.dev = 'http://bayin5.mycwgs.com/';
                    config.img.ossDomain = response.data.data.ossDomain;
                    config.RemoteIpInited = true;
                    resolve()
                },
                fail: () => {
                    config.RemoteIpInited = true;
                    resolve()
                }
            })
        });
  }
}

export default config

以上就是分析uniapp如何動態(tài)獲取接口域名的詳細內容,更多關于uniapp動態(tài)獲取接口域名的資料請關注腳本之家其它相關文章!

相關文章

  • JS實現雙擊屏幕滾動效果代碼

    JS實現雙擊屏幕滾動效果代碼

    這篇文章主要介紹了JS實現雙擊屏幕滾動效果代碼,涉及JavaScript鼠標事件的響應及頁面元素屬性的動態(tài)變換技巧,需要的朋友可以參考下
    2015-10-10
  • javascript運算符——邏輯運算符全面解析

    javascript運算符——邏輯運算符全面解析

    下面小編就為大家?guī)硪黄猨avascript運算符——邏輯運算符詳解。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 萊鳥介紹javascript onclick事件

    萊鳥介紹javascript onclick事件

    這篇文章主要介紹了萊鳥介紹javascript onclick事件的相關資料,需要的朋友可以參考下
    2016-01-01
  • JS加密插件CryptoJS實現的Base64加密示例

    JS加密插件CryptoJS實現的Base64加密示例

    這篇文章主要介紹了JS加密插件CryptoJS實現的Base64加密,結合實例形式分析了CryptoJS進行base64加密的簡單實現技巧,需要的朋友可以參考下
    2018-08-08
  • JavaScript數組扁平轉樹形結構數據(Tree)的實現

    JavaScript數組扁平轉樹形結構數據(Tree)的實現

    本文主要介紹了JavaScript數組扁平轉樹形結構數據(Tree)的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 微信小程序生成海報分享朋友圈的實現方法

    微信小程序生成海報分享朋友圈的實現方法

    利用微信強大的社交能力通過小程序達到裂變的目的,拉取新用戶。下面小編給大家?guī)砹宋⑿判〕绦蛏珊蠓窒砼笥讶Φ膶崿F方法,感興趣的朋友跟隨小編一起看看吧
    2019-05-05
  • javascript稀疏數組(sparse array)和密集數組用法分析

    javascript稀疏數組(sparse array)和密集數組用法分析

    這篇文章主要介紹了javascript稀疏數組(sparse array)和密集數組用法,分析javascript稀疏數組和密集數組的功能、定義與使用方法,需要的朋友可以參考下
    2016-12-12
  • Bootstrap縮略圖與警告框學習使用

    Bootstrap縮略圖與警告框學習使用

    這篇文章主要為大家詳細介紹了Bootstrap縮略圖與警告框學習使用的相關資料,希望通過這篇文章和大家更多的去學習Bootstrap縮略圖與警告框,從中得到收獲
    2017-02-02
  • Javascript 實現放大鏡效果實例詳解

    Javascript 實現放大鏡效果實例詳解

    這篇文章主要介紹了Javascript 實現放大鏡效果實例詳解的相關資料,這里附有實現實例代碼,具有參考價值,需要的朋友可以參考下
    2016-12-12
  • 對layui數據表格動態(tài)cols(字段)動態(tài)變化詳解

    對layui數據表格動態(tài)cols(字段)動態(tài)變化詳解

    今天小編就為大家分享一篇對layui數據表格動態(tài)cols(字段)動態(tài)變化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10

最新評論