什么是 rue-config
rue-config 是一个基于 dotenv 的 Node.js
配置加载器。它可以非常方便地从 .env
文件或环境变量中加载配置,支持默认值和类型转换,使得配置文件的管理变得更加简单。
安装
使用npm进行安装:
npm install rue-config
如何使用
rue-config支持多种参数配置方式:
rueConfig.init()
初始化rueConfig.load()
从.env
文件或环境变量中加载配置rueConfig.get(key)
获取配置项
初始化
初始化 rue-config
的时候,你可以传入一些配置参数。下面是默认配置:
{ encoding: 'utf8', path: path.resolve(process.cwd(), '.env'), debug: false }
你可以根据需要修改这些参数来适应你的项目:
const RueConfig = require('rue-config') RueConfig.init({ encoding: 'utf8', path: path.resolve(process.cwd(), '.env'), debug: true })
从 .env
文件或环境变量中加载配置
使用 .env
文件或环境变量中的配置项非常简单。你只需要在你的项目(根目录)中添加 .env
文件,并在其中添加配置项。
例如,你需要添加一个名为 PORT
的配置项,它的值是 3000
。你可以在 .env
文件中这样写:
PORT=3000
然后,在你的代码中引入 rue-config
并调用 load()
方法来加载配置项:
const RueConfig = require('rue-config') RueConfig.load() const port = RueConfig.get('PORT') console.log(port) // 3000
在这个例子中,我们加载了 .env
文件中的配置,并使用 get()
方法获取了 PORT
配置项的值。
获取配置项
通过调用 RueConfig.get(key)
方法,你可以获取 .env
文件或环境变量中指定的配置项的值。如果没有找到该配置项,则此方法将返回 undefined
。
注意,调用 get()
方法时,你需要提供你想要访问的配置项的键。例如,如果我们想要获取在 .env
文件中声明的 PORT
配置项的值,我们可以这样写:
const RueConfig = require('rue-config') RueConfig.load() const port = RueConfig.get('PORT') console.log(port) // 3000
默认值
你可以设置一个或多个默认值,以便在没有在 .env
文件或环境变量中对应的配置项时提供默认值。为此,只需在调用 RueConfig.init()
方法时传入一个对象和默认值,如下面的例子所示:
-- -------------------- ---- ------- ----- --------- - --------------------- ---------------- --------- ------- ----- --------------------------- -------- ------ ----- --------- - ----- ----- -------- ------- -------- -------- - -- ---------------- ----- ---- - --------------------- ----- ------ - ------------------------ ----- ------ - ------------------------ ----------------- -- ---- ------------------- -- ---- ------------------- -- ------
在上面的例子中,我们设置了默认值 PORT: 3000, DB_USER: 'root'
和 DB_PASS: '123456'
。这意味着,即使没有在 .env
文件或环境变量中找到这些配置项,我们仍然可以使用这些默认值。
类型转换
在 rue-config
中,支持将配置项的值转换成希望的类型。你可以在初始化 rue-config
的时候传入一个 types
对象。
types
对象的键是在 .env
文件或环境变量中声明的配置项的键,其值可以是一个类型字符串或一个自定义函数。
-- -------------------- ---- ------- ----- --------- - --------------------- ---------------- --------- ------- ----- --------------------------- -------- ------ ----- --------- - ----- ----- -------- ------- -------- -------- -- ------ - ----- --------- -------- ------- -- -------------------- -------- ------- -- ------------------- - -- ---------------- ----- ---- - --------------------- -- ---- -------- ----- ------ - ------------------------ -- ------ -------- ----- ------ - ------------------------ -- -------- -------- ------------------ ----- -- -------- ------------------ ------- -- -------- ------------------ ------- -- -------- --------------------------------- -- ------ --------------------------------- -- --------
在上面的例子中,我们为 PORT
设置了 types['PORT'] = 'number'
,这意味着,如果我们在 .env
文件或环境变量中声明了 PORT
,它将自动被转换成 number
类型。
此外,我们还为 DB_USER
和 DB_PASS
设置了一个自定义函数,来将这些配置项的值转换成小写和大写字符串。
总结
在本教程中,我们介绍了 rue-config
,一个非常实用的 Node.js
配置加载器。它可以轻松地从 .env
文件或环境变量中加载配置,并支持默认值和类型转换。这个库可以提高你的程序开发的效率,使你的配置文件更易于维护。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6005736881e8991b448e964e