在laravel-admin專案中需要完成一個需求:選擇一個select選項後,需要同時聯動賦值給select2,select3選項
有了解到laravel-admin本身帶有 ->loads()
方法,所以嘗試使用了,如下:
$form->select('goods', __('商品名稱'))->options(function(){
$list = [];
$goods = Good::where('state',1)->get();
foreach ($goods as $k => $v) {
$list[$v['id']] = $v['name'];
}
return $list;
})->loads(['supplier_goods','purchaser_good'],['/api/getsuppliergoods','/api/getpurchasergoods']);
$form->multipleSelect('supplier_goods', __('供應商商品'));
$form->multipleSelect('purchaser_good', __('採購商商品'));
實際執行後,發現 supplier_goods 可以正常選擇,但是 purchaser_good 選項框可以正常顯示內容,但是無法選中內容,也沒有發現報錯。
將 multipleSelect 改為 select :$form->select('purchaser_good', __('採購商商品'));
再次執行,發現還是無法選擇,並且在點選時會報如下錯誤:
經過一番檢視,終於發現問題,原來是 '/api/getpurchasergoods'
對應的控制器裡方法寫的有問題。
官方的統一寫法是 ->get(['id', DB::raw('purchaser_id as text')])->toarray();
但是這裡由於我最初是想直接獲取採購商id的,所以就改成:->get(['purchaser_id', DB::raw('purchaser_id as text')])->toarray();
因此可能導致了導致框架找不到對應的id,所以無法進一步選擇操作。
本作品採用《CC 協議》,轉載必須註明作者和本文連結