如何在nuxt中添加proxyTable代理?

背景

在本地开发vue项目的时候,当你习惯了proxytable解决本地跨域的问题,切换到nuxt的时候,你会发现,添加了proxytable设置并没有什么作用,那是因为你是用的vue脚手架生成的vue项目,它里面已经帮你写好了相关的proxytable的设置代码。

build/dev-server.js

// proxy api requestsObject.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 })// 生产模式不需要 buildif (!isProd) {  const builder = new Builder(nuxt)  builder.build()}// proxy api requests这里就是添加的proxyTable中间价的设置了var proxyTable = config.dev.proxyTableObject.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.config.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"    }}

登录后复制

相关推荐:

如何在网站中添加视频

如何在http请求头中添加cookie

以上就是如何在nuxt中添加proxyTable代理?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2744193.html

(0)
上一篇 2025年3月8日 03:16:25
下一篇 2025年3月8日 03:16:32

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论