Angular 实战——配置使用环境变量

只想快速解决问题的,请直接看粗体部分。

为了更清晰,更快速的了解 Angular 环境配置的架构,请看此图:

下面具体内容也会按照图上所示来介绍。

添加环境配置文件

  1. 创建文件,不过这个步骤在使用 Angular cli 构建的项目的时候已经默认配置好了(如果没有,在项目终端执行 ng generate environments ),在 src -> environments 目录,并且目录下会有几个不同的文件,如下:

名字可以随便取,默认是 Angular 的命名规范, 目录+环境.ts ,一般用默认提供的这两到三个文件就够了,当然如果环境多的情况,就复制出来几份,比如图上: environment.alpha.ts

  1. 配置文件内容

默认需要导出一个对象,默认名字为 environment,如果 想要添加变量,直接在 environment 里添加键值对,比如添加一个baseURL ,下图所示:

两点需要注意:

  1. 多个环境配置文件,默认使用 environment.ts 作为默认/基础文件配置,就是说在项目中使用的地方导入的是该文件 ,可能有同学会问:我想以其他文件作为默认配置行吗,我的回答是:行,但是一定要保证在 angular.json 中映射正确,为了避免配置失误,建议还是不要改。
  2. environment 这个名字也可以修改,但是一定要注意其他引用的地方也要同步修改,比如 main.ts 启动项目时,其他的环境配置文件 一定要和默认/基础文件导出的对象命名保持一致

映射环境配置文件

angular.json 是项目的基础,它配置了打包、服务启动、代理......等,环境配置也是其中的一项

  1. 打开 angular.json 文件,找到节点:"architect" -> "build" -> "configurations",然后添加环境替换规则,如图:

2. 找到节点:"serve" -> "configurations" 添加 "alpha" 节点(内容复制其他环境的就行),如图:

3. 为了后面测试配置的环境是否生效,这里配置默认按照 alpha 运行。

使用环境配置文件

配置结束,使用起来就非常简单了,只需要注意一点,导入的环境文件是基础环境(上面 replace 的文件,通常是 environment.ts),如图:

从页面看下内容:

OK,大功告成!

番外篇:合并通用环境变量

angular 中只提到了配置文件替换规则,可实际开发中有很大部分情况下需要的是合并规则,更详细说:很多环境变量是相同的,我们期望是只写一遍,关于合并规则,angular.json 并没有提供(至少本人没有发现),但是我们可以利用 js 特性手动合并一下,借助一个默认配置文件,配置通用的环境变量,然后在其他文件中做解构合并操作,如图示:

最后

告辞,谢,勿送,望三连 🌹

参考

相关推荐
GIS之路4 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒5 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
Kagol6 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉6 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau6 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生6 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼6 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范
明君879976 小时前
Flutter 如何给图片添加多行文字水印
前端·flutter
leolee187 小时前
Redux Toolkit 实战使用指南
前端·react.js·redux
bluceli7 小时前
React Hooks最佳实践:写出优雅高效的组件代码
前端·react.js