位置: IT常识 - 正文

vue项目根据不同环境动态配置接口请求ip及全局变量(vue环境变量配置)(vue调用同一个组件)

编辑:rootadmin
vue项目根据不同环境动态配置接口请求ip及全局变量(vue环境变量配置)

推荐整理分享vue项目根据不同环境动态配置接口请求ip及全局变量(vue环境变量配置)(vue调用同一个组件),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue项目根据不同环境切换登录不同系统,vue根据不同用户跳转到不同页面,vue多个项目,vue项目根据不同环境切换登录不同系统,vue根据不同条件import,vue根据不同用户跳转到不同页面,vue项目根据不同环境切换登录不同系统,vue根据不同用户跳转到不同页面,内容如对您有帮助,希望把文章链接给更多的朋友!

在项目的开发过程中,我们常常会遇到根据不同的环境需要切换不同的ip的问题,例如在项目部署到测试服时需要将接口请求ip替换成测试服的ip,部署到正式服时又需要将接口请求ip替换成正式服对应的ip,有些公司还有预发环境等,这样在每次部署不同环境的项目前都需要先手动切换ip,这样既繁琐又易出错。本篇文章就记录了本人在解决这一问题的详细步骤。

配置步骤1.在项目的根目录下新建 .env.xxx 文件

vue脚手架创建的项目默认目录结构如下:

根据环境个数在根目录下新增 .env.xxx 文件

 如上,三个 .env.xxx 文件后缀名(文件后缀名可自定义)为development、production、test,可分别对应为开发环境、生产环境和测试环境。如果还需要预发环境,则还可继续新增一个 .env.pre 文件代表预发环境。

每个环境都会加载的变量

如果还需要设置每个环境都需要加载的变量,则可以添加 .env 文件,如果没有,则可以不建此文件。(即每个环境对应变量的变量值都是一样的时候,则可以将变量定义在公用的.env文件中,而对应每个环境的 .env.xxx文件中则不需要再重复定义此变量)

2.在对应环境的 .env.xxx 文件中添加变量

在.env.xxx 文件中只有 NODE_ENV,BASE_URL 和以 VUE_APP_ 开头的变量会通过 webpack.DefinePlugin 静态地嵌入到客户端侧的代码中。

NODE_ENV : 主要用于标识当前的环境BASE_URL: vue.config.js 中的 publicPath 选项相符,即你的应用会部署到的基础路径VUE_APP_* : 自定义变量vue项目根据不同环境动态配置接口请求ip及全局变量(vue环境变量配置)(vue调用同一个组件)

.env.development(开发环境) 文件代码

.env.production(生产环境) 文件代码

.env.test(测试环境) 文件代码

.env(所有环境都会加载的变量) 文件代码

3.package.json 文件配置对应环境打包命令

vue脚手架创建的项目默认配置如下:

vue-cli-service serve:配置默认是使用的development对应环境的环境变量(当然也可以自己手动指定对应的环境,在现有命令后面加上 --mode development即可,完整命令:vue-cli-service serve --mode development), 也就是说执行npm run serve,会将.env.development文件和.env文件里面的变量加入项目代码中vue-cli-service build:配置默认是使用的production对应环境的环境变量, 也就是说执行npm run build,会将.env.production文件和.env文件里面的变量加入项目代码中

添加测试服打包命令(运行命令:npm run build:test)

在package.json文件中的 scripts 对象中添加如下代码:

 vue-cli-service build --mode test :命令中的test对应的是 .env.xxx文件中设置NODE_ENV变量的值,如果没有设置NODE_ENV变量,则默认以 .env.xxx 文件的后缀名为准,如果也找不到.env.test文件,则打包报错,

如果想在本地直接使用测试服的环境变量也可以在package.json 中再配置项目启动命令,配置如下(运行命令:npm run serve:test):

 或者直接修改现有serve 的运行模式: 

配置完成后如何在项目中使用在请求js文件中,可用于替换请求接口的ip,达到根据不同的环境请求不同的ip的效果在vue文件中,可当作全局变量使用,类似于在vue中定义的全局常量在vue.config.js文件中使用,可用于判断当前的打包环境,根据不同的环境进行一些打包优化配置vue-cli的index.html中使用,可用于加载公司统一定义的一些js、css等头部文件(需根据各个环境引入各自的js和css)1.请求接口的js文件/vue页面中使用 语法:process.env.变量名称

2.vue.config.js中根据环境变量判断打包环境,进行打包优化配置:

3.在vue-cli的index.html中使用

语法:<%= 变量名 %> html中根据不同环境,加载不同css/js文件

//css文件<link rel="stylesheet" href="<%= VUE_APP_API %>/header/head.css" rel="external nofollow" >//js文件<script type="text/javascript" src="<%= VUE_APP_API %>/footer.js"></script>

html中根据不同环境,加载不同本地js代码

<% if (process.env.NODE_ENV === 'production' ) { %> <script> window.test = 'xxxx' </script><% } %>

本文链接地址:https://www.jiuchutong.com/zhishi/295946.html 转载请保留说明!

上一篇:Bert 得到中文词向量(bert获取中文词向量)

下一篇:利用Matlab进行图像分割和边缘检测(利用matlab作图)

  • 税金及附加现金流量表
  • 房屋租赁房产税税率是怎样计算的
  • 财务要做哪些表
  • 房地产业如何确认收入
  • 进料加工出口退税政策
  • 现金流量表抵消分录
  • 残保金申报工资应该是实发数吗
  • 中小企业员工出去创业的例子
  • 上月未记账本月可以记账吗
  • 住宅小区共用部位有哪些
  • 捆绑销售行为怎么纳税
  • 收回已确认的坏账的应收账款
  • 供货商对账单跨月返利怎么做账?
  • 企业年金个人所得税扣除标准
  • 企业增加注册资金怎么办理
  • 公司收到一次性吸纳就业补贴款怎么分录
  • 收到借款确认书模板
  • 公司注销实收资本可以退回股东吗?
  • 法人的往来款可以转为实收资本吗?
  • 银行的期初数据怎么进行账务处理?
  • 贷款和应收款项在活跃市场中没有报价
  • 税种案例分析
  • 财产清查账务处理步骤
  • 非公益性赠送该怎么进行会计处理?
  • 城市维护建设税属于什么税种
  • 设备器具一次性扣除会计分录
  • 非贸易企业代扣代缴增值税和附加税如何做账?
  • 固定资产双倍余额递减法计提折旧公式
  • 微软正式宣布收购动视暴雪
  • 结转未交增值
  • 工程结算如何做账
  • 如何免费获得microsoft
  • 怎样搭建php开发平台
  • 应付账款收到票怎么做账
  • 冲回暂估分录
  • 建房转让协议书
  • 外商投资企业采用交易发生日的即期汇率
  • PHP:imageloadfont()的用法_GD库图像处理函数
  • 设备租赁的方式有哪些
  • Calanques de Piana岩层上的一个心形洞,法国科西嘉岛 (© joningall/Getty Images)
  • 悉尼奥林匹克公园
  • 九斑蛾,瑞士 (© Thomas Marent/Minden Pictures)
  • joomla模板制作教程
  • 持续集成的步骤
  • Win11 Build 23435 预览版今日发布: 文件管理器引入图库功能
  • framework core
  • 自动驾驶数据集 mev
  • 帝国cms使用手册
  • php注册功能
  • 怎么用java写代码
  • python requests检测响应状态码
  • phpcms2008
  • 发票专用章刻制
  • 企业收到收据老会计怎么入账
  • 现金折扣属于什么
  • 购买研发设备的发票可以申报创新券吗?
  • 农民专业合作社法
  • 去年已入账的材料怎么查
  • 企业间借款利息最新规定
  • 金融资产减值损失
  • 个人交五险一金多少钱一个月
  • 挂靠工程项目预交税金的会计分录如何做?
  • mysql常用命令
  • mysql 数据修改
  • 内存不够用如何升级系统
  • deepin直接安装
  • icg是什么文件
  • win7桌面怎么设置到d盘
  • win8玩游戏
  • Android OpenGL ES(七)----理解纹理与纹理过滤
  • css命名大全
  • 用unity做2d游戏
  • ie6怎么设置兼容性
  • shell脚本编写 方法
  • js点击div改变css样式
  • android 实例教程
  • static function FindObjectsOfType (type : Type) : Object[]
  • 人员进出管理系统
  • js new实现
  • pycharm flask框架
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设