vue實(shí)踐---根據(jù)不同環(huán)境,自動(dòng)轉(zhuǎn)換請(qǐng)求的url地址操作
一般的項(xiàng)目環(huán)境分為:本地環(huán)境,測(cè)試環(huán)境,預(yù)發(fā)環(huán)境,正式環(huán)境。 這些環(huán)境的域名一般是一樣的, 前端請(qǐng)求接口的url也會(huì)隨著這些環(huán)境的變化而改變,手動(dòng)修改有點(diǎn)麻煩,所以想個(gè)辦法,讓請(qǐng)求的地址根據(jù)域名改變而改變。
第一步:
建立一個(gè)RequestConfig.js 作為配置文件,內(nèi)容如下:
const APIMapping = {
project1: {
test: 'http://123.com',
local: 'http://abc.com'
},
project2: {
test: 'http://123.com',
local: 'http://abc.com'
}
}
const currentEnvMapping = {
'127.0.0.1': 'test',
'localhost': 'local',
}
export { currentEnvMapping, APIMapping }
這里只列舉了測(cè)試環(huán)境,和本地環(huán)境,其他環(huán)境使用方法一樣。
APIMapping是所有的項(xiàng)目,這里有 project1,project2 ;每個(gè)項(xiàng)目分為本地環(huán)境(test),測(cè)試環(huán)境(local);
currentEnvMapping 指明什么域名下使用本地環(huán)境的域名,還是測(cè)試環(huán)境的域名。
第二步
使用vuex, 建立一個(gè)store文件存放vuex, 然后再建立index.js存放數(shù)據(jù):
import Vue from 'vue'
import Vuex from 'vuex'
import { APIMapping, currentEnvMapping } from './../common/RequestConfig.js'
Vue.use(Vuex)
const state = {
// 這里currentEnvMapping[location.hostname]確定是test, 還是local環(huán)境
// APIMapping['project1']確定了是哪個(gè)項(xiàng)目
// APIMapping['project1'][currentEnvMapping][location.hostname]最終確定了url
RequestHost: APIMapping['project1'][currentEnvMapping[location.hostname]]
}
const getters = {
get_RequestHost: state => {
return state.RequestHost
}
}
export default new Vuex.Store({
state,
getters
})
第三步
就可以使用了,跟正常的vue一樣,代碼如下:
mounted(){
console.log(this.$store.getters.get_RequestHost)
}
具體的代碼看這里: https://github.com/YalongYan/vue-practice/tree/master/dynamic-request
補(bǔ)充知識(shí):vue-cli項(xiàng)目生產(chǎn)環(huán)境和開發(fā)環(huán)境請(qǐng)求接口配置,不用手動(dòng)切換,自動(dòng)切換地址的問題
1、在dev.env.js文件中添加配置(開發(fā)環(huán)境):
'use strict'
const merge = require('webpack-merge')
const prodEnv = require('./prod.env')
module.exports = merge(prodEnv, {
NODE_ENV: '"development"',
url_api: '"api"' // 添加的請(qǐng)求接口,鍵值都可以自定義,
})
2、在prod.env.js文件中添加配置(生產(chǎn)環(huán)境):
'use strict'
module.exports = {
NODE_ENV: '"production"',
url_api: '"http://192.168.0.30/server-carApp/"' // 添加的鍵值對(duì),鍵開發(fā)和生成環(huán)境要保持一致,值是打包后上線的地址
}
3、在axios請(qǐng)求文件中,通過process.env.url_api就可以拿到請(qǐng)求的根接口,
我的請(qǐng)求文件中的設(shè)置:
const service = axios.create({
baseURL: process.env.url_api, // 通過process.env.url_api拿到請(qǐng)求的地址
withCredentials: true,
timeout: 60 * 1000
})
我之所以在開發(fā)環(huán)境中配置url_api的值為api,是因?yàn)槲以赾onfig/index.js中配置的跨域代理寫的是api,
config下的index.js文件中關(guān)于跨域代理的配置
module.exports = {
dev: {
// Paths
assetsSubDirectory: 'static',
assetsPublicPath: '/',
proxyTable: {
'/api': {
target: 'http://192.168.0.30/server-carApp/', // 后臺(tái)接口
changeOrigin: true, // 是否開啟跨域
// secure: false, // 如果是https接口,需要配置這個(gè)
pathRewrite: {
'^/api': ''
}
}
},
。。。。。。
4、同樣的,在具體的.vue組件文件中,也可以通過process.env.url_api拿到根api接口地址,然后可以用字符串拼接,得到想要的完整url請(qǐng)求地址。
例如,在login.vue文件中,有一個(gè)圖片驗(yàn)證碼的地址,
<template>
<img :src="codeImgSrc" alt="圖片驗(yàn)證碼"/>
</template>
<script>
// 這樣根路徑就被引入進(jìn)來了,不用在打包上線的時(shí)候在具體的文件中改資源路徑
const imgUlr = process.env.url_api + '/main/validate/qrCode?w=300&h=80'
export default {
name: 'Login',
data() {
return {
codeImgSrc: imgUlr,
}
}
}
</script>
以上這篇vue實(shí)踐---根據(jù)不同環(huán)境,自動(dòng)轉(zhuǎn)換請(qǐng)求的url地址操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue利用localStorage本地緩存使頁面刷新驗(yàn)證碼不清零功能的實(shí)現(xiàn)
這篇文章主要介紹了Vue利用localStorage本地緩存使頁面刷新驗(yàn)證碼不清零功能的實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
Vue+Element ui實(shí)現(xiàn)樹形控件右鍵菜單
這篇文章主要為大家詳細(xì)介紹了Vue+Element ui實(shí)現(xiàn)樹形控件右鍵菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
基于vue開發(fā)微信小程序mpvue-docs跳轉(zhuǎn)頁面功能
這篇文章主要介紹了基于vue寫微信小程序mpvue-docs跳轉(zhuǎn)頁面,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04
vue中實(shí)現(xiàn)展示與隱藏側(cè)邊欄功能
這篇文章主要介紹了vue中實(shí)現(xiàn)展示與隱藏側(cè)邊欄功能,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
使用vue cli4.x搭建vue項(xiàng)目的過程詳解
這篇文章主要介紹了使用vue cli4.x搭建vue項(xiàng)目的過程,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
Vue路由跳轉(zhuǎn)傳參或打開新頁面跳轉(zhuǎn)的方法總結(jié)
這篇文章主要給大家介紹了關(guān)于Vue路由跳轉(zhuǎn)傳參或打開新頁面跳轉(zhuǎn)的相關(guān)資料,在使用Vue.js開發(fā)單頁面應(yīng)用時(shí)常常會(huì)遇到路由跳轉(zhuǎn)傳參的需求,需要的朋友可以參考下2023-07-07
解決vue項(xiàng)目中出現(xiàn)Invalid Host header的問題
這篇文章主要介紹了解決vue項(xiàng)目中出現(xiàn)"Invalid Host header"的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼
這篇文章主要介紹了vue中實(shí)現(xiàn)拖動(dòng)調(diào)整左右兩側(cè)div的寬度的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Vue3?計(jì)算屬性computed的實(shí)現(xiàn)原理
這篇文章主要介紹了Vue3?計(jì)算屬性computed的實(shí)現(xiàn)原理,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-08-08

