どのようにnuxtにproxyTable代理を追加しますか?
2741 ワード
背景
ローカルでvueプロジェクトを開発した時に、proxyTableでローカルエリアを跨ぐ問題を解決することに慣れました。nuxtに切り替えた時、proxyTableの設定を追加しても効果がないことが分かります。それはあなたが使っているvue足場で生成されたvueプロジェクトです。その中には既に関連するproxyTableの設定コードが作成されています。
build/dev-server.js
nuxtにもミドルウェアの概念がありますが、このミドルウェアはexpressのミドルウェアではなく、nuxtにどうやって追加しますか?
どうしますか
まず、インストール依存
運行が不便だと思いますが、コマンドをpackage.jsonファイルに追加してもいいです。
ローカルでvueプロジェクトを開発した時に、proxyTableでローカルエリアを跨ぐ問題を解決することに慣れました。nuxtに切り替えた時、proxyTableの設定を追加しても効果がないことが分かります。それはあなたが使っているvue足場で生成されたvueプロジェクトです。その中には既に関連するproxyTableの設定コードが作成されています。
build/dev-server.js
// proxy api requests
Object.keys(proxyTable).forEach(function (context) {
var options = proxyTable[context]
if (typeof options === 'string') {
options = { target: options }
}
app.use(proxyMiddleware(options.filter || context, options))
})
ここはexpressミドルウェアという形をとっていますが、使用の依存はhttp-proxy-middlewareです。nuxtにもミドルウェアの概念がありますが、このミドルウェアはexpressのミドルウェアではなく、nuxtにどうやって追加しますか?
どうしますか
まず、インストール依存
npm install --save-dev express http-proxy-middleware
ルートディレクトリでファイルserver.jsを作成します。
const { Nuxt, Builder } = require('nuxt')
const app = require('express')()
var proxyMiddleware = require('http-proxy-middleware')
var config = require('./nuxt.config')
// Nuxt.js:
const isProd = process.env.NODE_ENV === 'production'
const nuxt = new Nuxt({ dev: !isProd })
// build
if (!isProd) {
const builder = new Builder(nuxt)
builder.build()
}
// proxy api requests proxyTable
var proxyTable = config.dev.proxyTable
Object.keys(proxyTable).forEach(function (context) {
var options = proxyTable[context]
if (typeof options === 'string') {
options = { target: options }
}
app.use(proxyMiddleware(options.filter || context, options))
})
app.use(nuxt.render)// nuxt
app.listen(3000)
console.log('Server is listening on http://localhost:3000')
nuxt.co nfig.jsに下記のコードを追加します。
module.exports = {
dev: {
proxyTable: {
'/api':
{
target: 'http://localhost:7001', //
pathRewrite: { '^/api': '/' }
}
}
}
}
そしてnode server.jsを運行すればいいです。運行が不便だと思いますが、コマンドをpackage.jsonファイルに追加してもいいです。
{
"scripts": {
"dev": "nuxt --port=8080",
"build": "nuxt build",
"start": "nuxt start",
"generate": "nuxt generate",
"lint": "eslint --ext .js,.vue --ignore-path .gitignore .",
"precommit": "npm run lint",
"server": "node server.js"
}
}
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。