当前位置: 首页 > news >正文

安徽茶叶学会 网站建设游戏推广员是诈骗吗

安徽茶叶学会 网站建设,游戏推广员是诈骗吗,企业做网站公司排名,衡水哪有做网站的文章目录 场景解决方案思路实现步骤创建项目目标前端配置安装cross-env配置vue.config.js配置package.json 测试 场景 一个前端,需要同时和N个后端联调 一个需求里有若干个模块,分别给不同的后端开发,前端需要和N个后端联调 本地开启一个端…

文章目录

  • 场景
  • 解决方案
    • 思路
    • 实现步骤
      • 创建项目
      • 目标
      • 前端配置
        • 安装`cross-env`
        • 配置`vue.config.js`
        • 配置package.json
    • 测试

场景

    1. 一个前端,需要同时和N个后端联调
    1. 一个需求里有若干个模块,分别给不同的后端开发,前端需要和N个后端联调
    1. 本地开启一个端口给测试,然后你需要去做其他的需求,但是其他的需求需要连接另一个后端接口
    1. 其他情况,总之:1个前端 VS N个后端

上述场景,都是一个前端,联调N个后端的场景,你可能没遇到过,但是确实存在上述的场景。尤其是第三种最为常见,你会一直等测试完了、再去换一个后端代理地址接着开发吗?当然不能,这样做很浪费时间,说明你不是一个合格的牛马,牛马的觉悟不够,牛马是不会让自己闲着的。

那么,怎么办呢?和A联调时proxy指向url-A,和B联调时proxy指向url-B……换其他人联调时,你是把本地项目关掉,然后换个proxy代理、再重启一下吗?

当然可以,如果你不嫌麻烦的话!那么有没有好办法呢?

这个问题问得好,当然有了!

解决方案

本例以vue2的vue-cli方式【webpack】为例

思路

既然vue.config.js能代理一个proxy,那么能不能代理多个proxy呢?当然能!

本文先讲解传统模式的代理,以后写一个函数式代理
vite有更好的代理方式,暂且不表

实现步骤

创建项目

创建一个空的vue2项目

vue create project-name

默认情况下,npm run serve会启动8080端口

目标

我希望不同的端口,指向不同的后端代理proxy地址,如:

  • 8100端口,代理后端7001端口
  • 8105端口,代理后端7002端口

没毛病吧?本文以代理2个后端为例,其余的大家自行补充

前端配置

安装cross-env
yarn add cross-env

cross-env是nodejs设置环境变量的工具,它解决了不同操作系统之间环境变量设置语法不一致的问题,具体可自行搜索

配置vue.config.js
const { defineConfig } = require('@vue/cli-service')module.exports = defineConfig({transpileDependencies: true,// webpack-dev-server 相关配置devServer: {host: '0.0.0.0',port: process.env.PORT || 8100,open: false,proxy: {'/api': {target: getProxyTarget(process.env.PORT),changeOrigin: true,pathRewrite: { '^/api': '' }}},},
})function getProxyTarget(port) {switch (port) {case '8100':return 'http://127.0.0.1:7001'case '8105':return 'http://127.0.0.1:7002'default:return 'http://127.0.0.1:7001' // 默认代理地址}
}

上述代码,默认设置启动端口为8100,并且getProxyTarget函数可以根据不同的端口,指向不同的代理地址。

配置package.json
{"name": "more-proxy","version": "0.1.0","private": true,"scripts": {"serve": "vue-cli-service serve","serve:8005": "cross-env PORT=8105 vue-cli-service serve","build": "vue-cli-service build"},"dependencies": {"cross-env": "^7.0.3","vue": "^2.6.14"},"devDependencies": {"@vue/cli-service": "~5.0.0","vue-template-compiler": "^2.6.14"},"browserslist": ["> 1%","last 2 versions","not dead"]
}

上述代码,重点是serve:8005这行,就是你要代理哪个端口,这里需要你在vue.config.js写对应的映照proxy

测试

上述配置已经实现了我们的需求,那么,具体测试一下吧。

本地启动两个nodejs服务,分别为7001和7002端口,内容如下

/// 7001端口
const http = require('http');const hostname = '127.0.0.1';
const port = 7001;const server = http.createServer((req, res) => {res.statusCode = 200;res.setHeader('Content-Type', 'text/plain');res.end('my port is 7001!');
});server.listen(port, hostname, () => {console.log(`Server running at http://${hostname}:${port}/`);
});
/// 7002端口
const http = require('http');const hostname = '127.0.0.1';
const port = 7002;const server = http.createServer((req, res) => {res.statusCode = 200;res.setHeader('Content-Type', 'text/plain');res.end('my port is 7002!');
});server.listen(port, hostname, () => {console.log(`Server running at http://${hostname}:${port}/`);
});

然后前端把上面的2个端口启动,写一个测试函数

mounted() {fetch('/api').then(() => {})
}

效果如下:
8100已经成功代理7001了
在这里插入图片描述
同样的,8105也代理了7002
在这里插入图片描述

其余的vue3,react,也可以用类似的思路

如果感兴趣,可以点一下关注,后续会出函数式1前端 VS N后端,更加优雅

如果有其他更好的方案,可以评论留言。

http://www.khdw.cn/news/7376.html

相关文章:

  • 温州网站改版哪家好百度明星人气榜排名
  • 做网站公司300元钱班级优化大师下载安装
  • 网站恶意刷网络营销的现状分析
  • 无锡企业网上迁移成都seo推广
  • 2017网站开发新技术足球联赛排名
  • 微信商城小程序搭建教程宁波seo公司排名
  • 做网站建设的公司排名网络销售员每天做什么
  • 绍兴网站制作推广直通车官网
  • 淘宝做任务赚钱网站网站制作公司排行榜
  • 洛阳网站建设价格搜索指数查询
  • 做网站买域名多少钱吸引人的微信软文
  • 营销型企业网站怎么制作公司品牌营销策划
  • 烟台莱山城市建设网站郑州营销型网站建设
  • 电商网站竞价推广策略上海关键词自动排名
  • wordpress主题教程关键词优化排名第一
  • 网上商城电商项目的管理步骤seo免费优化网站
  • 大红门做网站上海全网推广
  • 广东网站建设建站模板友链交易平台源码
  • 厦门35网站建设公司2020年可用好用的搜索引擎
  • 中国建设银网站搜索引擎优化通常要注意的问题有
  • 辽宁千山科技做网站怎么样凡科建站怎么样
  • 宁波网站设计服务最有效的app推广方式有哪些
  • wordpress ios app成都谷歌seo
  • 易云巢做营销型网站磁力猫搜索引擎入口官网
  • 公司网站建设开发维护工作总结网站seo重庆
  • 厦门外贸网站廊坊seo推广
  • 淄博网站制作公司百度官网登录入口手机版
  • 网站后台哪些功能需要前端配合网站优化关键词排名
  • wordpress模板建站教程网络销售入门基本知识
  • 青海免费网站建设营销方案100例