欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

利用vue怎么解決跨域問題-創(chuàng)新互聯(lián)

利用vue怎么解決跨域問題?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

創(chuàng)新互聯(lián)建站是專業(yè)的慶云網(wǎng)站建設(shè)公司,慶云接單;提供做網(wǎng)站、網(wǎng)站制作,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行慶云網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

如何在vue里面優(yōu)雅的解決跨域,路由沖突問題

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

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

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

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

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

正確的姿勢

如果把所有的接口,統(tǒng)一規(guī)范為一個入口,在一定程度上會解決沖突

把以上配置統(tǒng)一前面加上 /api/

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

如果我們配置成這種方式,在使用http請求的時候就會發(fā)生變化,會在請求前面加上一個api,相對路由也會發(fā)生變化,也會在接口前面加上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/' 會默認讀取本地的域

上面這樣配置的話,不會區(qū)分生產(chǎn)和開發(fā)環(huán)境

在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 里面引入,這樣可以保證動態(tài)的匹配生產(chǎn)和開發(fā)的定義前綴

import apiConfig from '../config/api.config'

import Axios from 'axios'
import VueAxios from 'vue-axios'

Vue.use(VueAxios, Axios)
Axios.defaults.baseURL = apiConfig.baseUrl

經(jīng)過上面配置后,在dom里面可以這樣輕松的訪問,也不需要在任何組件里面引入axios模塊了。

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

最終代碼

在代理里面配置

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

在config里面的api.config.js 配置

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

const isPro = Object.is(process.env.NODE_ENV, 'production')

module.exports = {
 baseUrl: isPro ? 'http://www.vnshop.cn/api/' : 'api/'
}

關(guān)于生產(chǎn)和開發(fā)配置不太了解

可以去 dev-server.js 里面看配置代碼

const webpackConfig = (process.env.NODE_ENV === 'testing' || process.env.NODE_ENV === 'production') ?
 require('./webpack.prod.conf') :
 require('./webpack.dev.conf')

在main.js 入口文件里面配置

import apiConfig from '../config/api.config'

import Axios from 'axios'
import VueAxios from 'vue-axios'

Vue.use(VueAxios, Axios)
Axios.defaults.baseURL = apiConfig.baseUrl
在dom里面請求api的姿勢
 logout(){
  this.$http.post('/users/logout').then(result=>{
   let res = result.data;
   this.nickName = '';
   console.log(res);
  })
 },
 getGoods(){
  this.$http.post('/goods/list').then(result=>{
   let res = result.data;
   this.nickName = '';
   console.log(res);
  })
 }

看完上述內(nèi)容,你們掌握利用vue怎么解決跨域問題的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

文章名稱:利用vue怎么解決跨域問題-創(chuàng)新互聯(lián)
瀏覽地址:http://aaarwkj.com/article34/cdhpse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作建站公司、外貿(mào)建站、App設(shè)計網(wǎng)站排名、用戶體驗

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
超薄丝袜美腿一二三区在线播放| 国产三级精品三级精品在一区| 日本高清不卡免费在线观看视频一二三区 | 亚洲精品一级黄色片| 亚洲成人久久久久久久| 蜜桃国产精品视频网站| 日韩高清精品视频在线| 亚洲日本在线观看一区| 日本在线一区二区不卡视频| 人妻91一区二区三区| 国产丝袜美腿诱惑久久| 中文字幕日韩精品久久| 中文在线中文天堂黄色片| 日韩美女搞黄色的网站| 欧美日韩国产一下老妇| 亚洲精品日韩av专区| 中文字幕av日韩在线| 国产三级伦理在线播放| 日韩精品成人一区二区三区免费| 夫妻爱爱视频在线观看| 日本区一区二区三高清视频| 欧美日韩在线国产一区| 久久亚洲中文字幕丝袜长腿| 精品人妻一区二区三区不卡| 成人欧美黑人一区二区| 久久精品人妻一区二区| 激情少妇一区二区三区| 一区二区三区免费视频少妇| 欧美在线日韩一区二区| 国产精品久久123区| 国产女主播在线观看一区| 国产亚洲精品视频在线网| 国产精品青青在线观看爽香蕉| 嫩草网站国产精品一区二| 日韩视频免费看一区二区| 亚洲一区二区三区精品在线| 亚洲激情在线观看一区| 精品毛片久久久久久久久| 欧美av在线免费观看| 日韩国产一区二区三区精品 | 中文字幕亚洲精品99|