Maison  >  Article  >  développement back-end  >  Comment gérer uniformément PHP Enum ?

Comment gérer uniformément PHP Enum ?

Guanhui
Guanhuiavant
2020-06-19 18:04:342353parcourir

Comment gérer uniformément PHP Enum ?

Installer

composer require fangx/php-enum

Créer

Utilisez la commande ./vendor/bin/enum pour créer une classe d'énumération.

./vendor/bin/enum FooEnum --enum="1=foo" --enum="b=bar" --path=Enums

Cette commande crée par défaut un fichier FooEnum.php dans le répertoire Enums du répertoire courant. est la suivante :

<?phpnamespace Enums;use Fangx\Enum\AbstractEnum;class FooEnum extends AbstractEnum{
    const FOO = "f", __FOO = "foo";
    const BAR = "b", __BAR = "bar";}

Utilisez la classe d'énumération

pour hériter de FangxEnumAbstractEnum par défaut. Les méthodes suivantes peuvent être appelées de manière statique :

  • toArray(Format $format = null, Filter $filter = null)
  • toJson(Format $format = null, Filter $filter = null)
  • desc($key, $default = &#39;Undefined&#39;)

Obtenir toutes les énumérations valeurs

<?phpclass FooEnum extends \Fangx\Enum\AbstractEnum{
    const FOO = &#39;f&#39;, __FOO = &#39;foo&#39;;
    const BAR = &#39;b&#39;, __BAR = &#39;bar&#39;;}/**
 * [&#39;f&#39; => 'foo', 'b' => 'bar']
 */FooEnum::toArray();

Obtenir les informations de description de la valeur d'énumération

<?phpclass FooEnum extends \Fangx\Enum\AbstractEnum{
    const FOO = &#39;f&#39;, __FOO = &#39;foo&#39;;
    const BAR = &#39;b&#39;, __BAR = &#39;bar&#39;;}/**
 * "foo"
 */FooEnum::desc(&#39;f&#39;);/**
 * "bar"
 */FooEnum::desc(FooEnum::BAR);

Utiliser le format pour contraindre le retour value

<?phpclass FooFormat implements \Fangx\Enum\Contracts\Format{
    public function parse(\Fangx\Enum\Contracts\Definition $definition): array
    {
        return [[&#39;key&#39; => $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);

Filtrer les valeurs d'énumération à l'aide de règles.

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);

Utilisez des collections personnalisées car tous les types d'énumération sont cohérents avec <.>.FooEnum
<?phpclass BarEnum extends \Fangx\Enum\AbstractEnum{
    public function all()
    {
        return [
            new \Fangx\Enum\Definition('f', 'foo'),
            new \Fangx\Enum\Definition('b', 'bar'),
        ];
    }}

                                                                                                                                                                                                                                             

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer