更新复选框形式发送的记录的最佳方法是什么。如何知道哪一个未被选中。
我的算法未设置所有值,然后再次检查请求中的ID。此外,由于所有值每一次都会更新,因此会引起时间戳问题。
public function plansUpdate(Request $request){
//set all plans as not default to handle unchecked
$plans = $this->planService->getAllPlans()->pluck('id');
PlanModel::whereIn('id', $plans)->update(['is_default' => false]);
//set checked plans as default
$defaultPlans = $request->get('default-plans');
PlanModel::whereIn('id', $defaultPlans)->update(['is_default' => true]);
return redirect()->back();
}
我想执行更好的解决方案,即仅在表单中更改的值在后端被“触摸”。
答案 0 :(得分:0)
像这样创建它,不要忘记用实际ID替换$id
:
<input type="hidden" name="default_plans[$id]" value="0" />
<input type="checkbox" name="default_plains[$id]" value="1" />
然后在您的php代码中迭代模型并在交易中更新它们。
public function plansUpdate(Request $requets) {
$plans = $this->planService->getAllPlans();
$defaultPlans = $request->get('default_plans');
DB::beginTransaction();
foreach($plans as $plan) {
$plan->is_default = boolval($defaultPlans[$plan->id] ?? false);
$plan->save();
}
DB::commit();
}