1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務(wù)時(shí)間:8:30-17:00
      你可能遇到了下面的問(wèn)題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
      vue中怎么解決跨域路由沖突問(wèn)題-創(chuàng)新互聯(lián)

      今天就跟大家聊聊有關(guān)vue中怎么解決跨域路由沖突問(wèn)題,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

      創(chuàng)新互聯(lián)專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、潁上網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)商城網(wǎng)站開(kāi)發(fā)、集團(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ù)。

      vue 簡(jiǎn)介

      Vue.js(讀音 /vju?/, 類似于 view) 是一套構(gòu)建用戶界面的漸進(jìn)式框架。

      Vue 只關(guān)注視圖層, 采用自底向上增量開(kāi)發(fā)的設(shè)計(jì)。

      Vue 的目標(biāo)是通過(guò)盡可能簡(jiǎn)單的 API 實(shí)現(xiàn)響應(yīng)的數(shù)據(jù)綁定和組合的視圖組件。

      Vue 學(xué)習(xí)起來(lái)非常簡(jiǎn)單,本教程基于 Vue 2.1.8 版本測(cè)試。

      當(dāng)我們?cè)诼酚衫锩媾渲贸梢韵麓砜梢越鉀Q跨域問(wèn)題

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

      這種配置方式在一定程度上解決了跨域問(wèn)題,但是會(huì)帶來(lái)一些問(wèn)題,

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

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

      正確的姿勢(shì)

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

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

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

      如果我們配置成這種方式,在使用http請(qǐng)求的時(shí)候就會(huì)發(fā)生變化,會(huì)在請(qǐng)求前面加上一個(gè)api,相對(duì)路由也會(huì)發(fā)生變化,也會(huì)在接口前面加上api,這樣也會(huì)很麻煩,我們可以使用以下方式來(lái)解決這個(gè)問(wèn)題

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

      上面這個(gè)代碼,就是把咱們虛擬的這個(gè)api接口,去掉,此時(shí)真正去后端請(qǐng)求的時(shí)候,不會(huì)加上api這個(gè)前綴了,那么這樣我們前臺(tái)http請(qǐng)求的時(shí)候,還必須加上api前綴才能匹配到這個(gè)代理,代碼如下:

      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直接默認(rèn)值是 api,這樣我們每次訪問(wèn)的時(shí)候,自動(dòng)補(bǔ)上這個(gè)api前綴,就不需要我們自己手工在每個(gè)接口上面寫這個(gè)前綴了

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

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

      如果這配置 ‘a(chǎn)pi/' 會(huì)默認(rèn)讀取本地的域

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

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

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

      然后在main.js 里面引入,這樣可以保證動(dòng)態(tài)的匹配生產(chǎn)和開(kāi)發(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)過(guò)上面配置后,在dom里面可以這樣輕松的訪問(wèn),也不需要在任何組件里面引入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 文件夾里面新建一個(gè) 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)和開(kāi)發(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里面請(qǐng)求api的姿勢(shì)

      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);
        })
       }

      PS:下面通過(guò)一段代碼學(xué)習(xí)下vue下跨域設(shè)置

      1、在使用vue開(kāi)發(fā)的時(shí)候經(jīng)常要涉及到跨域的問(wèn)題,其實(shí)在vue cli中是有我們?cè)O(shè)置跨域請(qǐng)求的文件的。

      2、當(dāng)跨域無(wú)法請(qǐng)求的時(shí)候我們可以修改工程下config文件夾下的index.js中的dev:{}部分。

      dev: {
        env: require('./dev.env'),
        port: 8080,
        autoOpenBrowser: false,
        assetsSubDirectory: 'static',
        assetsPublicPath: '/',
        proxyTable: {
          '/api': {
            target: 'http://api.douban.com/v2',
            changeOrigin: true,
            pathRewrite: {
              '^/api': ''
            }
          }
        },
        // CSS Sourcemaps off by default because relative paths are "buggy"
        // with this option, according to the CSS-Loader README
        // (https://github.com/webpack/css-loader#sourcemaps)
        // In our experience, they generally work as expected,
        // just be aware of this issue when enabling this option.
        cssSourceMap: false
      }

      將target設(shè)置為我們需要訪問(wèn)的域名。

      3、然后在main.js中設(shè)置全局屬性:

      Vue.prototype.HOST = '/api'

      4、至此,我們就可以在全局使用這個(gè)域名了,如下:

      var url = this.HOST + '/movie/in_theaters'
        this.$http.get(url).then(res => {
         this.movieList = res.data.subjects;
        },res => {
         console.info('調(diào)用失敗');
        });

      看完上述內(nèi)容,你們對(duì)vue中怎么解決跨域路由沖突問(wèn)題有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝大家的支持。

      另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


      當(dāng)前題目:vue中怎么解決跨域路由沖突問(wèn)題-創(chuàng)新互聯(lián)
      標(biāo)題來(lái)源:http://www.ef60e0e.cn/article/docjhj.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        葫芦岛市| 赞皇县| 台东县| 开封县| 抚州市| 田阳县| 互助| 昆山市| 巫溪县| 惠水县| 新河县| 桐庐县| 东乡县| 兴城市| 秀山| 长治市| 甘孜| 徐汇区| 宁阳县| 泾川县| 杭锦后旗| 叶城县| 永泰县| 新津县| 屯门区| 盘山县| 丹寨县| 托克逊县| 蓬溪县| 鹤山市| 苏尼特右旗| 祁连县| 南城县| 万源市| 广饶县| 宝鸡市| 营口市| 灵璧县| 绵竹市| 淮阳县| 庆云县|