详解如何在nuxt中添加proxyTable代理
背景
在本地开发vue项目的时候,当你习惯了proxyTable解决本地跨域的问题,切换到nuxt的时候,你会发现,添加了proxyTable设置并没有什么作用,那是因为你是用的vue脚手架生成的vue项目,它里面已经帮你写好了相关的proxyTable的设置代码。
build/dev-server.js
//proxyapirequests
Object.keys(proxyTable).forEach(function(context){
varoptions=proxyTable[context]
if(typeofoptions==='string'){
options={target:options}
}
app.use(proxyMiddleware(options.filter||context,options))
})
这里是采用的express中间件的形式,使用的依赖是http-proxy-middleware
nuxt也有中间件的概念,不过这个中间件不是express的中间件,那么我们怎么添加到nuxt里面去呢?
怎么做
首先,安装依赖
npminstall--save-devexpresshttp-proxy-middleware
然后在根目录创建一个文件server.js
const{Nuxt,Builder}=require('nuxt')
constapp=require('express')()
varproxyMiddleware=require('http-proxy-middleware')
varconfig=require('./nuxt.config')
//我们用这些选项初始化Nuxt.js:
constisProd=process.env.NODE_ENV==='production'
constnuxt=newNuxt({dev:!isProd})
//生产模式不需要build
if(!isProd){
constbuilder=newBuilder(nuxt)
builder.build()
}
//proxyapirequests这里就是添加的proxyTable中间价的设置了
varproxyTable=config.dev.proxyTable
Object.keys(proxyTable).forEach(function(context){
varoptions=proxyTable[context]
if(typeofoptions==='string'){
options={target:options}
}
app.use(proxyMiddleware(options.filter||context,options))
})
app.use(nuxt.render)//这里是添加nuxt渲染层服务的中间件
app.listen(3000)
console.log('Serverislisteningonhttp://localhost:3000')
然后在nuxt.config.js中添加如下代码
module.exports={
dev:{
proxyTable:{
'/api':
{
target:'http://localhost:7001',//
pathRewrite:{'^/api':'/'}
}
}
}
}
然后nodeserver.js运行就可以了。
觉得运行不方便还可以把命令添加到package.json文件里。
{
"scripts":{
"dev":"nuxt--port=8080",
"build":"nuxtbuild",
"start":"nuxtstart",
"generate":"nuxtgenerate",
"lint":"eslint--ext.js,.vue--ignore-path.gitignore.",
"precommit":"npmrunlint",
"server":"nodeserver.js"
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。