1. 程式人生 > >Vue-cli proxyTable 解決開發環境的跨域問題

Vue-cli proxyTable 解決開發環境的跨域問題

復雜 如何解決 url pac 是我 conf 適用於 clas 映射

和後端聯調時總是會面對惱人的跨域問題,最近基於Vue開發項目時也遇到了這個問題,兩邊各自想了一堆辦法,查了一堆資料,加了一堆參數,最後還得我把自己的localhost映射成上線時將要使用的域名。
今天翻看代碼時,突然發現vue-cli的config文件裏有一個參數叫proxyTable,看這個名字就感覺能解決問題,於是我就去搜了一下,果然。在vuejs-templates,也就是vue-cli的使用的模板插件裏,有關於API proxy的說明,使用的就是這個參數。
https://vuejs-templates.github.io/webpack/proxy.html
這個參數主要是一個地址映射表,你可以通過設置將復雜的url簡化,例如我們要請求的地址是api.xxxxxxxx.com/list/1

,可以按照如下設置:

proxyTable: {
  ‘/list‘: {
    target: ‘http://api.xxxxxxxx.com‘,
    pathRewrite: {
      ‘^/list‘: ‘/list‘
    }
  }
}

這樣我們在寫url的時候,只用寫成/list/1就可以代表api.xxxxxxxx.com/list/1.
那麽又是如何解決跨域問題的呢?其實在上面的‘list‘的參數裏有一個changeOrigin參數,接收一個布爾值,如果設置為true,那麽本地會虛擬一個服務端接收你的請求並代你發送該請求,這樣就不會有跨域問題了,當然這只適用於開發環境。增加的代碼如下所示:

proxyTable: {
  ‘/list‘: {
    target: ‘http://api.xxxxxxxx.com‘,
    changeOrigin: true,
    pathRewrite: {
      ‘^/list‘: ‘/list‘
    }
  }
}

Vue-cli proxyTable 解決開發環境的跨域問題