arr*_*l12 7 php laravel laravel-4
我有许多不同的位置插入和更新我的数据库的方式,我希望能够trim()在插入数据库之前输入用户.我知道在模型中我可以做类似下面的事情,但我不想为每个领域做这件事.有没有办法设置适用于所有字段的通用setter?
例:
public function setSomFieldAttribute($value) {
return $this->attributes['some_field'] = trim($value);
}
Run Code Online (Sandbox Code Playgroud)
您可能会覆盖这些方法:
<?php
class Post extends Eloquent {
protected function getAttributeValue($key)
{
$value = parent::getAttributeValue($key);
return is_string($value) ? trim($value) : $value;
}
public function setAttribute($key, $value)
{
parent::setAttribute($key, $value);
if (is_string($value))
{
$this->attributes[$key] = trim($value);
}
}
}
Run Code Online (Sandbox Code Playgroud)
你永远不应该再获得未经修改的价值.
编辑:
在这里测试过,我没有空格:
Route::any('test', ['as' => 'test', function()
{
$d = Post::find(2);
$d->title_en = " Markdown Example ";
dd($d);
}]);
Run Code Online (Sandbox Code Playgroud)
使用Model Events本产品和运行trim上创建或更新模型时所需的每个字段.
class Model extends \Eloquent {
...
public static function boot() {
parent::boot();
static::saving(function($model){
$model->some_field = trim($model->some_field);
});
}
...
}
Run Code Online (Sandbox Code Playgroud)
用法示例:
$model = new Model;
$model->some_field = ' foobar ';
$model->save();
// $model->some_field should now be trimmed
Run Code Online (Sandbox Code Playgroud)