laravel-admin的框架已經定義好的多級聯動可以去官網查看,這里就不再進行贅述,但是使用中發現功能與想要的東西有些偏差,剛進來默認的時候不好用,就自己改了改,增加了一個默認的方法。
以城市和地區的二級聯動為例,當我選擇沈陽時,地區列表變成和平區、沈河區、鐵西區等等,當我選擇大連時顯示瓦房店、甘井子等等
首先,按照laravel-admin的文檔,在Model中添加
- public function __construct(array $attributes = [])
- {
- parent::__construct($attributes);
- $this->setParentColumn('pid');
- $this->setOrderColumn('sort');
- $this->setTitleColumn('name');
- }
然后在form上添加城市和地區的select控件
- protected function form()
- {
- return Admin::form(AreaModel::class, function (Form $form) {
- $form->text('name', '名稱')->rules("required");
- $form->select('city_id','城市')->options(
- DealCityModel::selectOptionsNoRoot()
- )->load('pid', 'district')->loadOne('pid', 'district');//load方法是框架自帶的,定義在vendor=>encore=>laravel-admin=>src=>Form=>Field=>Select文件中,loadone是自己寫的,在后面會給出代碼district為自己定義的方法,pid是根據城市的變化而變化的下拉列表框名稱,也就是下面這個。
- $form->select('pid','地區')->options(array(0 =>'請選擇地區'));
- });
- }
在from方法后面新建一個district方法
- public function district(Request $request)
- {
- $cityId = $request->get('q');
- $list = AreaModel::where(['city_id' => $cityId, 'pid' => 0])->get(['id', DB::raw('name as text')]);
- foreach ($list as $key => $value) {
- $arr[] = array("id" => $value->id, "text" => $value->text);
- }
- return $arr;//返回數組到地區的option
- }
在vendor=>encore=>laravel-admin=>src=>Form=>Field=>Select文件里load方法后新建一個方法命名為loadone,代碼如下:
- public function loadOne($field, $sourceUrl, $idField = 'id', $textField = 'text')
- {
- if (Str::contains($field, '.')) {
- $field = $this->formatName($field);
- $class = str_replace(['[', ']'], '_', $field);
- } else {
- $class = $field;
- }
- $script = <<<EOT
- $(function(){
- var target = $(".$class");
- $.get("$sourceUrl?q="+$("{$this->getElementClassSelector()}").val(), function (data) {
- target.find("option").remove();
- $(target).select2({
- data: $.map(data, function (d) {
- d.id = d.$idField;
- d.text = d.$textField;
- return d;
- })
- });
- });
- });
- EOT;
- Admin::script($script);
- return $this;
- }
其實就是相當于給load方法增加了一個默認時的數據填充。
最后,千萬別忘記在路由上加上district方法哈,要把定義district的路由寫在上面→
以上這篇laravel-admin的多級聯動方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持我們。
原文鏈接:https://blog.csdn.net/qq_33541033/article/details/78707250