博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何在nuxt中添加proxyTable代理
阅读量:6046 次
发布时间:2019-06-20

本文共 2016 字,大约阅读时间需要 6 分钟。

背景

在本地开发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"    }}

来源:

转载于:https://www.cnblogs.com/lovellll/p/10180025.html

你可能感兴趣的文章
JVM运行时内存结构学习
查看>>
管理维护Replica Sets
查看>>
asp.net core 系列 3 依赖注入服务
查看>>
HashMap 和 HashTable区别
查看>>
git 格式化输出版本信息
查看>>
js 防止重复提交表单
查看>>
日期工具类 DateTools
查看>>
数据结构5.4_m元多项式的表示
查看>>
14. Longest Common Prefix
查看>>
Servlet页面登录的数据库验证程序(一)
查看>>
使用Promise 解决回调地狱
查看>>
rem简单实现移动端适配
查看>>
ios中利用委托在二个视图间传值
查看>>
iOS融云使用原理篇
查看>>
第六章
查看>>
golang+es 爬取网易云音乐评论
查看>>
Math Constants
查看>>
Ajax.BeginForm的异步提交数据 简介
查看>>
Oracle 11g不能导出空表的三种解决方法
查看>>
Wordpress 文章添加副标题
查看>>