首頁 >web前端 >uni-app >詳解uniapp專案中如何引入axios

詳解uniapp專案中如何引入axios

青灯夜游
青灯夜游轉載
2021-09-15 19:41:5316649瀏覽

下面uniapp教學專欄為大家介紹一下uniapp專案中引入axios的方法,了解withCredentials允許獲取cookie和後端配置的跨域不可同時使用的一些基本知識,希望對大家有所幫助!

詳解uniapp專案中如何引入axios

已安裝axios

#1、先檢查是否安裝npm 工具:工具--> 外掛安裝

詳解uniapp專案中如何引入axios

#2、檢查是否安裝npm,如果沒有可以去看我的這篇文章:windows安裝node.js用npm安裝vue

#3、安裝後在目前目錄下開啟內建終端:(和前幾步一樣檢查外掛程式安裝與否)

詳解uniapp專案中如何引入axios

4、在終端機輸入:npm install axios 安裝axios

詳解uniapp專案中如何引入axios

5、安裝後如下所示:(node_modules 出現axios)

詳解uniapp專案中如何引入axios

#uniapp 專案設定axios

  • #建立utils 檔案按自己所需建立.js 檔案 

    詳解uniapp專案中如何引入axios

  • # 介紹axios

import Vue from 'vue'
import axios from 'axios'
  • 設定如下:(注意:withCredentials允許取得cookie 和後端配置的跨域不可同時使用,會報錯哦提醒你了!)

import Vue from 'vue'
import axios from 'axios'

// create an axios instance
const service = axios.create({
	baseURL: 'https://www.yongjiachen.top/jccrm', // url = base url + request url
	//withCredentials: true, // send cookies when cross-domain requests 注意:withCredentials和后端配置的cross跨域不可同时使用
	timeout: 6000, // request timeout
	crossDomain: true
})

// request拦截器,在请求之前做一些处理
service.interceptors.request.use(
    config => {
        // if (store.state.token) {
        //     // 给请求头添加user-token
        //     config.headers["user-token"] = store.state.token;
        // }
        console.log('请求拦截成功')
        return config;
    },
    error => {
        console.log(error); // for debug
        return Promise.reject(error);
    }
); 

//配置成功后的拦截器
service.interceptors.response.use(res => {
    if (res.data.status== 200) {
        return res.data
    } else {
        return Promise.reject(res.data.msg);
    }
}, error => {
	if (error.response.status) {
		switch (error.response.status) {
			case 401:
				break;
			default:
				break;
		}
	}
    return Promise.reject(error)
})


// 在main.js中放入这段自定义适配器的代码,就可以实现uniapp的app和小程序开发中能使用axios进行跨域网络请求,并支持携带cookie
axios.defaults.adapter = function(config) { 
    return new Promise((resolve, reject) => {
        console.log(config)
        var settle = require('axios/lib/core/settle');
        var buildURL = require('axios/lib/helpers/buildURL');
        uni.request({
            method: config.method.toUpperCase(),
            url: config.baseURL + buildURL(config.url, config.params, config.paramsSerializer),
            header: config.headers,
            data: config.data,
            dataType: config.dataType,
            responseType: config.responseType,
            sslVerify: config.sslVerify,
            complete: function complete(response) {
                console.log("执行完成:",response)
                response = {
                    data: response.data,
                    status: response.statusCode,
                    errMsg: response.errMsg,
                    header: response.header,
                    config: config
                };

                settle(resolve, reject, response);
            }
        })
    })
}

export default service
  • 在專案根目錄的main.js 設定引入全域axios

    詳解uniapp專案中如何引入axios

// 引入封装后的axios
import axios from './utils/request/request.js'
/**
 * 给Vue函数添加一个原型属性$axios 指向Axios
 * 这样做的好处是在vue实例或组件中不用再去重复引用Axios 直接用this.$axios就能执行axios 方法了
 * 在.vue中使用,this.$axios.get
 * @param {Object} config
 */
Vue.prototype.$axios = axios
  • #愉快的使用axios

    詳解uniapp專案中如何引入axios

  • #效果圖:

    詳解uniapp專案中如何引入axios

##原文網址:https://juejin.cn/post/7005042333288759333作者:Sunny_Chen

######更多程式設計相關知識,請造訪更多程式相關知識,請造訪:###程式設計影片###! ! ###

以上是詳解uniapp專案中如何引入axios的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:掘金--Sunny_Chen。如有侵權,請聯絡admin@php.cn刪除