安装
composer require fangx/php-enum
创建使用 ./vendor/bin/enum 命令创建一个枚举类.
./vendor/bin/enum fooenum --enum=1=foo --enum=b=bar --path=enums
该命令默认在 当前目录的 enums 目录下创建一个 fooenum.php 文件. 文件内容如下:
<?phpnamespace enums;use fangx\enum\abstractenum;class fooenum extends abstractenum{ const foo = "f", __foo = "foo"; const bar = "b", __bar = "bar";}
使用枚举类默认继承 \fangx\enum\abstractenum. 可以静态调用以下方法:
toarray(format $format = null, filter $filter = null)tojson(format $format = null, filter $filter = null)desc($key, $default = 'undefined')获取所有的枚举值<?phpclass fooenum extends \fangx\enum\abstractenum{ const foo = 'f', __foo = 'foo'; const bar = 'b', __bar = 'bar';}/** * ['f' => 'foo', 'b' => 'bar'] */fooenum::toarray();
获取枚举值的描述信息<?phpclass fooenum extends \fangx\enum\abstractenum{ const foo = 'f', __foo = 'foo'; const bar = 'b', __bar = 'bar';}/** * "foo" */fooenum::desc('f');/** * "bar" */fooenum::desc(fooenum::bar);
使用格式来约束返回值<?phpclass fooformat implements \fangx\enum\contracts\format{ public function parse(\fangx\enum\contracts\definition $definition): array { return [['key' => $definition->getkey() , 'value' => $definition->getvalue()]]; }}class fooenum extends \fangx\enum\abstractenum{ const foo = 'f', __foo = 'foo'; const bar = 'b', __bar = 'bar';}/** * [['key' => 'f', 'value' => 'foo'], ['key' => 'b', 'value' => 'bar'],] */$format = new fooformat();fooenum::toarray($format);
通过规则来过来过滤枚举值.class foofilter implements \fangx\enum\contracts\filter{ public function __invoke(\fangx\enum\contracts\definition $definition) { return $definition->getkey() === 'f'; }}/** * ['f' => 'foo'] */$filter = new foofilter();fooenum::toarray(null, $filter);
使用自定义的集合来作为所有的枚举类型, 其他使用方法与 fooenum 一致.
推荐教程:《php》
以上就是如何统一管理的 php enum?的详细内容。