我有一个日期和时间输入字段,我将日期和时间字段合并在一起,并试图将这两个值存储在数据库中。
问题::当我从数据库中检索日期时,该日期以字符串而不是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"
}
}
答案 0 :(得分:1)
添加后:
protected $dates = ['end_date'];
您不再需要变种器。
您可以简单地调用属性:
$task = Task::first();
dd($task->end_date);