ホームページ  >  記事  >  ウェブフロントエンド  >  クロスドメインルーティングの競合を解決するための Vue のアイデアについて

クロスドメインルーティングの競合を解決するための Vue のアイデアについて

不言
不言オリジナル
2018-06-29 17:29:471693ブラウズ

この記事では主に、クロスドメインルーティングの競合の問題を解決するための Vue のアイデアを紹介します。これは、必要な友人に参照してもらえるように共有します。 720;/、ビューに似ています) は、ユーザー インターフェイスを構築するための進歩的なフレームワークです。この記事では、クロスドメイン ルーティングの競合を解決するための Vue のアイデアの分析について詳しく説明します。必要な方は参照してください

Vue の概要Vue.js (/vjuː/ と発音します)。 view) は、インターフェイス用のユーザー構築ツールのセットである Progressive フレームワークです。


Vue はビュー層のみに焦点を当てており、ボトムアップのインクリメンタル開発設計を採用しています。


Vue の目標は、可能な限りシンプルな API を通じてレスポンシブなデータ バインディングと合成ビュー コンポーネントを有効にすることです。


Vue は非常に簡単に学習できます。このチュートリアルは Vue 2.1.8 バージョンのテストに基づいています。


ルーティングに次のプロキシを設定すると、クロスドメインの問題を解決できます

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

この設定方法は、クロスドメインの問題をある程度解決しますが、いくつかの問題が発生します

たとえば、私たちの vue ルートは、この時点で競合が発生します

プロジェクト内に多数のインターフェイスがある場合、ここでそれらを設定するのは非常に面倒であり、ルーティングの競合も発生しやすくなります。

正しい姿勢

全てのインターフェースを一つの入り口として統一して統一すれば競合はある程度解決します

上記の設定を/api/で統一

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

このように設定すると, http リクエストを使用すると API が追加され、インターフェースの前にも API が追加されます。これも非常に面倒です。この問題を解決するには、次のメソッドを使用します。

proxyTable: {
   '/api/**': {
    target: 'http://localhost:3000',
    pathRewrite:{
     '^/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 プレフィックスが追加されます。は自動的に追加され、訪問するたびに API プレフィックスを手動で追加する必要はありません。このプレフィックスはインターフェイスに書き込まれます

エントリ ファイルで次のように設定します:

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

'と指定すると、デフォルトでローカルドメインが読み取られます

このように設定すると、本番環境と開発環境が区別されなくなります

configで、フォルダー

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

に新しいapi.config.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 で簡単に行うことができます アクセスのために、コンポーネントに 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/'
}

本番環境と開発構成についてはわかりません

を理解するには、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

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 の API をリクエストします。これがコードの一部です vue でのクロスドメイン設定について学びましょう 1. vue で開発する場合、クロスドメインの問題がよく発生します。実際、vue cli にはクロスドメイン リクエストを設定するためのファイルがあります。 。

2. クロスドメイン リクエストを実行できない場合は、プロジェクトの 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
}

アクセスする必要があるドメイン名にターゲットを設定します。

3. 次に main.js で global 属性を設定します:

Vue.prototype.HOST = '/api'

4. この時点で、次のようにこのドメイン名をグローバルに使用できます:

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

上記がこの記事の全内容です。皆さんの学習に役立ちます。その他の関連コンテンツについては、PHP 中国語 Web サイトに注目してください。

関連する推奨事項:

Vue 背景画像をパッケージ化した後の不正なアクセス パスの問題を解決する方法


Vue-cli proxyTable が開発環境におけるクロスドメインの問題を解決する方法


方法IE11でVue 2.0を解決する 空白のプロジェクトページの問題を開く


以上がクロスドメインルーティングの競合を解決するための Vue のアイデアについての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。