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

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

小云云
小云云オリジナル
2017-12-28 10:35:251660ブラウズ

Vue.js (/vjuː/ と発音、ビューに似ています) は、ユーザー インターフェイスを構築するための進歩的なフレームワークです。この記事では、クロスドメインルーティングの競合を解決するための Vue のアイデアの分析について詳しく説明します。必要な方はぜひ参考にしてください。

Vue の概要

Vue.js (/vjuː/ と発音、ビューに似ています) は、ユーザー インターフェイスを構築するための進歩的なフレームワークです。

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

PS:クロスを学びましょうコードの一部を使用した 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('调用失败');
  });

関連する推奨事項:

Ajax クロスの例の詳細な説明-ドメインリクエストの原則

jqueryでのAjaxクロスドメイン送信時の2つのリクエストの問題の解決策

Jsのクロスドメインを理解する方法

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

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