laxity7 / yii2-trim-behavior
在验证之前,截断模型中所有属性的所有空格和其他字符的行为
1.0.2
2024-06-02 19:23 UTC
Requires
- php: >=7.4|>=8.0
- yiisoft/yii2: 2.*
Requires (Dev)
- phpunit/phpunit: ^9.1.4
This package is auto-updated.
Last update: 2024-09-02 19:49:39 UTC
README
此行为在验证之前自动截断模型中所有属性的所有空格和其他字符。最简单的方法是将此行为添加到父类中,这样所有属性始终会被截断。
注意:行为会自动跳过任何非字符串和空值。
安装
通过composer安装
composer require laxity7/yii2-trim-behavior
或者,您可以在composer.json中手动添加依赖项
"laxity7/yii2-trim-behavior": "*"
如何使用
要使用TrimBehavior,将以下代码插入到您的Model/ActiveRecord类中
/** @inheritdoc */ public function behaviors(): array { return [ 'trimAttributes' => \laxity7\yii2\behaviors\TrimBehavior::class, // trim all attributes // ... other behaviors ]; }
您还可以传递以下参数
- fields
string[](默认为[])要处理的字段列表。默认为所有字段。 - mask
string(默认为' \t\n\r �')简单地列出您想要去除的所有字符。您可以使用TrimBehavior::DEFAULT_MASK将您的字符和默认值组合起来 - once
string[](默认为true)运行行为一次并在之后分离。
因此,完整的设置列表如下所示
/** @inheritdoc */ public function behaviors(): array { return [ [ 'class' => \laxity7\yii2\behaviors\TrimBehavior::class, 'fields' => ['foo', 'bar'], 'mask' => '_' . TrimBehavior::DEFAULT_MASK, 'once' => false, ], ]; }
如果您只想截断某个类中的特定字段,则最好使用验证规则的过滤器
/** @inheritdoc */ public function rules() { return [ [['filedName1', 'filedName1'], 'filter', 'filter' => 'trim'], // ... other rules ]; }