十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
怎么在laravel-admin中实现多级联动?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
创新互联主营陕西网站建设的网络公司,主营网站建设方案,成都app软件开发公司,陕西h5微信小程序开发搭建,陕西网站营销推广欢迎陕西等地区企业咨询首先,按照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 = <<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 是一套简洁、优雅的PHP Web开发框架。它可以让你从面条一样杂乱的代码中解脱出来;它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁、富于表达力。
看完上述内容,你们掌握怎么在laravel-admin中实现多级联动的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!