dida / config
A Config Component.
v1.0.0
2021-04-04 19:10 UTC
Requires
- php: ^5.5 || ^7.0
This package is auto-updated.
Last update: 2025-01-21 23:48:43 UTC
README
Dida\Config
是一个配置组件,可以方便地对 App 的配置项进行各种操作。它是 宙品科技 开源的 Dida 框架 的一个功能组件。
API
Config::has($key)
-- 检查是否有指定 key 的配置。Config::set($key, $value)
-- 设置一个配置项。Config::get($key, $default = null)
-- 获取指定配置项,如果配置项不存在,返回 default 值。Config::remove($key)
-- 删除一个配置项。Config::keys()
-- 获取所有配置项的 keys。Config::sortKeys()
-- 对配置项按 key 排序。Config::clear()
-- 删除所有配置项。Config::merge(array $confs)
-- 批量合并一个配置项数组。Config::getKeysByGroup($group)
-- 获取指定 group 的所有 keys。Config::getItemsByGroup($group)
-- 获取指定 group 的所有配置项。Config::groupExpand($group, array $items)
--将给出的 items 扩展到指定的 group 上。Config::groupPack($group)
-- 对给出的 group 进行压缩,返回压缩后的配置数组。Config::groupClear($group)
-- 删除指定 group 的所有配置项。Config::load($filepath, $group = null)
-- 从文件中载入配置。
使用说明
一个
load()
可以读取的配置文件示例:<?php return [ "foo" => 1, "bar" => 2, "mysql.host" => "localhost", "mysql.user" => "root", "mysql.password" => "password", ];
merge()
调用的是array_merge()
函数。$confA = ["db.user"=>'root', "a"=>1, "b"=>2]; Config::merge($confA); // 运行后,结果如下: // Config::$items = [ // "db.user" => 'root', // "a" => 1, // "b" => 2, // ] $confB = ["a"=>9, "c"=>3]; Config::merge($confB); // 运行后,结果如下: // Config::$items = [ // "db.user" => 'root', // "a" => 9, // "b" => 2, // "c" => 3, // ]
groupExpand()
和groupPack()
是一对逆过程:$confA = [""=>0, "a"=>1, "b"=>2, "c"=>3]; // 将$confA扩展到db组里面 Config::groupExpand("db", $confA); // 运行后,结果如下: // Config::$items = [ // "db" => 0, // "db.a" => 1, // "db.b" => 2, // "db.c" => 3, // ] // 把db组的所有配置项打包出来 $confB = Config::groupPack("db"); // 运行后,结果如下: // $confB = [""=>0, "a"=>1, "b"=>2, "c"=>3]
感谢
- 宙品科技,Zeupin LLC , 尤其是 Dida 框架团队。
版权声明
版权所有 (c) 上海宙品信息科技有限公司。
Copyright (c) 2017-2021 Zeupin LLC. http://zeupin.com
源代码采用 MIT 授权协议。
Licensed under The MIT License.
如需在您的项目中使用,必须保留本源代码中的完整版权声明。
Redistributions of files MUST retain the above copyright notice.