詳解Vue-cli代理解決跨域問(wèn)題

使用vue-cli調(diào)接口的時(shí)候,總是會(huì)出現(xiàn)垮與問(wèn)題,因?yàn)関ue的localhost與訪問(wèn)域名不一致導(dǎo)致。而這一點(diǎn),開(kāi)發(fā)者顯然也想到了,故而在vuejs-templates,也就是vue-cli的使用的模板插件里,有關(guān)于API proxy的說(shuō)明,這個(gè)配置就是將localhost映射成訪問(wèn)的域名。

創(chuàng)新互聯(lián)專注于企業(yè)成都全網(wǎng)營(yíng)銷、網(wǎng)站重做改版、臨澧網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站購(gòu)物商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為臨澧等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

那么何為代理?

代理服務(wù)器英文全稱是Proxy Server,其功能就是代理網(wǎng)絡(luò)用戶去取得網(wǎng)絡(luò)信息。形象的說(shuō):它是網(wǎng)絡(luò)信息的中轉(zhuǎn)站??梢院?jiǎn)單粗暴理解為把你的域名轉(zhuǎn)換成你訪問(wèn)的域名,(我這么記的,當(dāng)然可能并不恰當(dāng))形成同源,就能訪問(wèn)。

那么在vue里,如何設(shè)置代理?

1.config目錄找到index.js

詳解Vue-cli代理解決跨域問(wèn)題

2.在dev里添加proxyTable

 dev: {
  env: require('./dev.env'),
  port: 8080,
  autoOpenBrowser: true,
  assetsSubDirectory: 'static',
  assetsPublicPath: '/',
  proxyTable: {
    '/api':{
      target:"http://47.93.166.112/BrainPcWeb",//設(shè)置你調(diào)用的接口域名和端口號(hào) 別忘了加http
      changeOrigin:true,
      pathRewrite:{
        '^/api':''//這里理解成用‘/api'代替target里面的地址,后面組件中我們掉接口時(shí)直接用api代替 
             //比如我要調(diào)用'http://40.00.100.133:3002/user/login',直接寫(xiě)‘/api/user/login'即可
      }
    }
  }

這一步為止,你重新run一下vue已經(jīng)不存在跨域問(wèn)題了。

如果你想在main.js把a(bǔ)pi定義成全局變量也可以這樣,雖然多此一舉。代碼如下:

Vue.prototype.HOST = '/api'
//這時(shí),你的/api/user/login就可以換成this.HOST/user/login

但是注意了

這只是開(kāi)發(fā)環(huán)境(dev)中解決了跨域問(wèn)題,生產(chǎn)環(huán)境中真正部署到服務(wù)器上如果是非同源還是存在跨域問(wèn)題

部署到服務(wù)器上跨域解決問(wèn)題,以后項(xiàng)目布置會(huì)繼續(xù)更新。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

名稱欄目:詳解Vue-cli代理解決跨域問(wèn)題
網(wǎng)頁(yè)網(wǎng)址:http://muchs.cn/article46/jcpohg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、用戶體驗(yàn)微信公眾號(hào)、營(yíng)銷型網(wǎng)站建設(shè)微信小程序、企業(yè)建站

廣告

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

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司