
本教程详细介绍了在 php 8.1 及更高版本中如何高效地获取枚举(enum)的所有成员名称和支持值(backed values)。文章首先阐述了通过 cases() 方法结合 array_column 获取基本名称和支持值的方法,随后深入探讨了如何利用 trait 模式构建可复用的功能,以实现枚举名称、支持值列表以及键值对映射的自动化管理,从而提升代码的整洁性和可维护性。
PHP 8.1 引入了对枚举(Enums)的原生支持,为开发者提供了一种定义一组有限、命名值集合的强大方式。在实际开发中,经常需要获取枚举的所有成员名称或其关联的支持值。本文将详细介绍如何在 PHP 8.1 及更高版本中实现这一目标,并提供一种利用 Trait 模式进行高级管理的方法。
基础枚举值获取
PHP 的枚举提供了一个静态方法 cases(),它返回一个包含所有枚举成员实例的数组。每个实例都是一个 UnitEnum 或 BackedEnum 的对象,它们都拥有 name 属性,而 BackedEnum 额外拥有 value 属性。
获取枚举成员名称
对于任何类型的枚举,我们都可以通过 cases() 方法获取所有成员的名称。name 属性返回枚举成员的声明名称(例如 Hearts)。结合 array_column 函数,可以轻松提取所有名称。
Hearts [1] => Diamonds [2] => Clubs [3] => Spades)*/?>
获取支持值枚举(Backed Enum)的值
当枚举是支持值枚举(Backed Enum)时,每个成员除了名称外,还关联了一个具体的值(例如字符串或整数)。我们可以使用 value 属性来获取这些支持值。
立即学习“PHP免费学习笔记(深入)”;
H [1] => D [2] => C [3] => S)*/?>
高级应用:使用 Trait 增强枚举功能
为了避免在每个枚举中重复编写获取名称和值的逻辑,我们可以利用 PHP 的 Trait 特性来封装这些常用功能。通过创建一个 EnumToArray Trait,可以为任何枚举提供便捷的方法来获取其名称、值列表,甚至是一个键值对映射。
EnumToArray Trait 的实现
以下是一个 EnumToArray Trait 的示例,它提供了三个静态方法:names()、values() 和 array()。
代码说明:
names():使用 array_column 提取所有枚举成员的 name 属性。values():同样使用 array_column 提取所有枚举成员的 value 属性。这里加入了类型检查,确保只有 BackedEnum 才能调用此方法,否则会抛出异常。array():结合 values() 和 names(),使用 array_combine 创建一个关联数组,其中键是枚举的支持值,值是枚举成员的名称。同样进行了类型检查。
在枚举中使用 Trait
现在,我们可以将 EnumToArray Trait 应用到任何需要这些功能的枚举中。
Hearts [1] => Diamonds [2] => Clubs [3] => Spades)*/$suitValues = Suit::values();print_r($suitValues);/*Array( [0] => H [1] => D [2] => C [3] => S)*/$suitMap = Suit::array();print_r($suitMap);/*Array( [H] => Hearts [D] => Diamonds [C] => Clubs [S] => Spades)*/// 尝试在非 Backed Enum 上调用 values() 或 array() 会抛出异常/*enum Color { use EnumToArray; case Red; }try { Color::values();} catch (BadMethodCallException $e) { echo "Error: " . $e->getMessage() . "n";}// Output: Error: Color is not a Backed Enum.*/?>
通过这种方式,我们不仅能够轻松获取枚举的各种数据,还保持了枚举定义的简洁性,并通过 Trait 实现了功能的复用。
注意事项
PHP 版本要求: 枚举功能自 PHP 8.1 起可用。请确保您的 PHP 环境满足版本要求。cases() 返回值: cases() 方法返回的是 EnumCase 对象的数组,而不是简单的字符串或整数数组。array_column 的第二个参数 ‘name’ 或 ‘value’ 是访问这些对象属性的关键。value 属性: value 属性只存在于 BackedEnum(支持值枚举)的实例中。尝试在非 BackedEnum 上访问 value 属性会导致运行时错误或返回 null。在 Trait 中进行类型检查是良好的实践,可以提供更清晰的错误信息。Trait 的复用性: EnumToArray Trait 可以被任何需要类似功能的枚举复用,避免了代码冗余,提高了代码的可维护性。
总结
PHP 8.1 引入的枚举功能极大地提升了代码的清晰度和类型安全性。通过 cases() 方法结合 array_column,我们可以方便地获取枚举的所有成员名称和支持值。进一步地,利用 Trait 模式可以封装这些常用操作,创建出更具扩展性和维护性的枚举管理方案。掌握这些技巧,将有助于您在 PHP 项目中更高效、更优雅地使用枚举。
以上就是PHP 8.1+ 枚举(Enum)值获取与高级管理实践的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1293951.html
微信扫一扫
支付宝扫一扫