tigrov / yii2-enum
基于类常量的 Yii2 枚举类型行为
1.2.1
2018-11-04 17:55 UTC
Requires
- php: >=5.5.0
- yiisoft/yii2: ~2.0.0
README
基于类常量的 Yii2 枚举类型行为。
限制
自 1.1.0 版本起需要 PHP >= 5.5
安装
通过 composer 安装此扩展是首选方式。
运行以下命令之一:
php composer.phar require --prefer-dist tigrov/yii2-enum
或
"tigrov/yii2-enum": "~1.0"
将以下内容添加到您的 composer.json
文件的 require 部分:
用法
扩展安装后,您可以创建一个枚举行为,如下所示:
class Status extends \tigrov\enum\EnumBehavior { const ACTIVE = 'active'; const PENDING = 'pending'; const REJECTED = 'rejected'; const DELETED = 'deleted'; /** @var array list of attributes that are to be automatically humanized value */ public $attributes = ['status' => 'status_key']; /** @var string|null a message category for translation the values */ public static $messageCategory = 'status'; }
创建一个包含枚举字段的表
\Yii::$app->getDb()->createCommand() ->createTable('model', [ 'id' => 'pk', 'status_key' => 'string', ])->execute();
为表创建一个模型
class Model extends \yii\db\ActiveRecord { /** * @inheritdoc */ public function behaviors() { return [ Status::class, // 'status' => [ // 'class' => Status::class, // 'attributes' => ['status' => 'status_key'], // ], ]; } /** * @inheritdoc */ public function rules() { return [ [['status_key'], 'in', 'range' => Status::codes()], ]; } }
然后在您的代码中使用它们
/** * @var ActiveRecord $model */ $model = new Model; $model->status_key = Status::PENDING; // The field 'status' has humanize and translated value, see \yii\helpers\Inflector::humanize($word, true) $model->status; // is 'Pending' or translated value // To get all enum values Status::values(); // To get a display value Status::value(Status::PENDING); // is 'Pending' or translated value
示例
性别代码
class GenderEnum extends \tigrov\enum\EnumBehavior { const MALE = 'M'; const FEMALE = 'F'; /** * @var array list of attributes that are to be automatically humanized value * humanized => original attribute */ public $attributes = ['gender' => 'gender_code']; /** @var string|null a message category for translation the values */ public static $messageCategory = 'gender'; /** * Returns value for empty attribute value * @return string|null */ public static function emptyValue() { return static::t('Unspecified'); } } class Model extends \yii\db\ActiveRecord { public function behaviors() { return [ GenderEnum::class, ]; } public function rules() { return [ [['gender_code'], 'in', 'range' => GenderEnum::codes()], ]; } } $model->gender_code = GenderEnum::MALE; // is 'M' // The field 'gender' has humanize and translated value $model->gender; // is 'Male' or translated value $model->gender_code = null; $model->gender; // is 'Unspecified' or translated value. @see GenderEnum::emptyValue()
消息传递者名称
class MessengerEnum extends \tigrov\enum\EnumBehavior { const SKYPE = 'skype'; const WHATSAPP = 'whatsapp'; const VIBER = 'viber'; const FACEBOOK = 'facebook'; const IMESSAGE = 'imessage'; const TELEGRAM = 'telegram'; const LINE = 'line'; const JABBER = 'jabber'; const QQ = 'qq'; const BLACKBERRY = 'blackberry'; const AIM = 'aim'; const EBUDDY = 'ebuddy'; const YAHOO = 'yahoo'; const OTHER = 'other'; /** @var array list of attributes that are to be automatically humanized value */ public $attributes = ['type' => 'type_key']; /** * Values of Messengers * @param bool $withEmpty with empty value at first * @return array */ public static function values($withEmpty = false) { $values = parent::values($withEmpty); // Correct some values $values['whatsapp'] = 'WhatsApp'; $values['imessage'] = 'iMessage'; $values['qq'] = 'QQ'; $values['blackberry'] = 'BlackBerry'; $values['aim'] = 'AIM'; $values['ebuddy'] = 'eBuddy'; $values['other'] = \Yii::t('enum', 'Other'), return $values; } } $model->type_key = MessengerEnum::WHATSAPP; // is 'whatsapp' $model->type; // is 'WhatsApp'