提取数据时获取字符串而不是Carbon Object

时间:2018-08-17 21:01:47

标签: php laravel datetime php-carbon

我有一个日期和时间输入字段,我将日期和时间字段合并在一起,并试图将这两个值存储在数据库中。

问题::当我从数据库中检索日期时,该日期以字符串而不是Carbon对象的形式获取。为什么会这样?

我所拥有的:

我的输入字段:

{{Form::date('date', \Carbon\Carbon::today(),['class' => 'form-control mb-2 mr-sm-2 mb-sm-0'])}}
{{Form::time('time', \Carbon\Carbon::now()->timezone('Europe/Brussels'),['class' => 'form-control'])}}

控制器上的“我的商店”功能:

public function store(Request $request)
{

    $this ->validate($request, ['title' => 'required|max:25','description' => 'required|max:60']);

    $task = new Task;
    $task -> end_date = $request->input('date') . ' ' . $request->input('time');
    $task -> user_id = auth()->id();
    $task->save();

    return redirect('/tasks')->with('success', 'Task created');
}

我在其中设置属性的模型:

    class Task extends Model
{
    protected $fillable = ['title','description', 'end-date'];

    protected $dates = ['end_date'];

    public function comments()
    {
        return $this->hasMany(Comment::class);
    }

    public function user()
    {
        return $this->belongsTo(User::class);
    }

    public function setEndDateAttribute($date) 
    {

        $this->attributes['end_date'] = Carbon::createFromFormat('Y-m-d H:i:s', $date);

    }
    public function getEndDateAttribute($date) 
    {
       dd($date);
       // Result of this example: "2018-08-17 22:39:55"
    }

}

1 个答案:

答案 0 :(得分:1)

添加后:

protected $dates = ['end_date'];

您不再需要变种器。

您可以简单地调用属性:

$task = Task::first();
dd($task->end_date);