国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

vue解決跨域路由沖突問題思路解析

2024-05-06 15:24:51
字體:
來源:轉載
供稿:網友

vue 簡介

Vue.js(讀音 /vjuː/, 類似于 view) 是一套構建用戶界面的漸進式框架。

Vue 只關注視圖層, 采用自底向上增量開發的設計。

Vue 的目標是通過盡可能簡單的 API 實現響應的數據綁定和組合的視圖組件。

Vue 學習起來非常簡單,本教程基于 Vue 2.1.8 版本測試。

當我們在路由里面配置成以下代理可以解決跨域問題

proxyTable: {   '/goods/*': {    target: 'http://localhost:3000'   },   '/users/*': {    target: 'http://localhost:3000'   }  },

這種配置方式在一定程度上解決了跨域問題,但是會帶來一些問題,

比如我們的vue 路由 也命名為 goods,這時候就會產生了沖突,

如果項目中接口很多,都在這里配置是很麻煩的,也容易產生路由沖突。

正確的姿勢

如果把所有的接口,統一規范為一個入口,在一定程度上會解決沖突

把以上配置統一前面加上 /api/

proxyTable: {   '/api/**': {    target: 'http://localhost:3000'   },  },

如果我們配置成這種方式,在使用http請求的時候就會發生變化,會在請求前面加上一個api,相對路由也會發生變化,也會在接口前面加上api,這樣也會很麻煩,我們可以使用以下方式來解決這個問題

proxyTable: {   '/api/**': {    target: 'http://localhost:3000',    pathRewrite:{     '^/api':'/'    }   },  },

上面這個代碼,就是把咱們虛擬的這個api接口,去掉,此時真正去后端請求的時候,不會加上api這個前綴了,那么這樣我們前臺http請求的時候,還必須加上api前綴才能匹配到這個代理,代碼如下:

logout(){  axios.post('/api/users/logout').then(result=>{   let res = result.data;   this.nickName = '';   console.log(res);  }) }, getGoods(){  axios.post('/api/goods/list').then(result=>{   let res = result.data;   this.nickName = '';   console.log(res);  }) }

我們可以利用axios的baseUrl直接默認值是 api,這樣我們每次訪問的時候,自動補上這個api前綴,就不需要我們自己手工在每個接口上面寫這個前綴了

在入口文件里面配置如下:

import Axios from 'axios'import VueAxios from 'vue-axios'Vue.use(VueAxios, Axios)Axios.defaults.baseURL = 'api'

如果這配置 ‘api/' 會默認讀取本地的域

上面這樣配置的話,不會區分生產和開發環境

在config 文件夾里面新建一個 api.config.js 配置文件

const isPro = Object.is(process.env.NODE_ENV, 'production')module.exports = { baseUrl: isPro ? 'http://www.vnshop.cn/api/' : 'api/'}

然后在main.js 里面引入,這樣可以保證動態的匹配生產和開發的定義前綴

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 商洛市| 璧山县| 盐池县| 保定市| 平潭县| 泰顺县| 洛南县| 玉树县| 偃师市| 陇南市| 牡丹江市| 同江市| 北海市| 共和县| 吴旗县| 中超| 青海省| 高雄市| 敦煌市| 广汉市| 松阳县| 图木舒克市| 贵港市| 峨山| 南汇区| 郑州市| 卢氏县| 灌云县| 张家界市| 萨迦县| 威海市| 大渡口区| 偏关县| 新昌县| 湖州市| 定结县| 二连浩特市| 邵东县| 长乐市| 彩票| 囊谦县|