どのようにnuxtにproxyTable代理を追加しますか?


背景
ローカルで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"
  }
}
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。