laxity7/yii2-trim-behavior

在验证之前,截断模型中所有属性的所有空格和其他字符的行为

安装次数: 3,222

依赖项: 0

建议者: 0

安全: 0

星标: 1

关注者: 1

分支: 0

开放性问题: 0

类型:yii2-extension

1.0.2 2024-06-02 19:23 UTC

This package is auto-updated.

Last update: 2024-09-02 19:49:39 UTC


README

License Latest Stable Version Total Downloads

此行为在验证之前自动截断模型中所有属性的所有空格和其他字符。最简单的方法是将此行为添加到父类中,这样所有属性始终会被截断。

注意:行为会自动跳过任何非字符串和空值。

安装

通过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
    ];
}