laravel-admin的多级联动方法

2025-05-27 0 63

laravel-admin的框架已经定义好的多级联动可以去官网查看,这里就不再进行赘述,但是使用中发现功能与想要的东西有些偏差,刚进来默认的时候不好用,就自己改了改,增加了一个默认的方法。

以城市和地区的二级联动为例,当我选择沈阳时,地区列表变成和平区、沈河区、铁西区等等,当我选择大连时显示瓦房店、甘井子等等

laravel-admin的多级联动方法

首先,按照laravel-admin的文档,在Model中添加

  1. public function __construct(array $attributes = [])
  2. {
  3. parent::__construct($attributes);
  4. $this->setParentColumn('pid');
  5. $this->setOrderColumn('sort');
  6. $this->setTitleColumn('name');
  7. }

然后在form上添加城市和地区的select控件

  1. protected function form()
  2. {
  3. return Admin::form(AreaModel::class, function (Form $form) {
  4. $form->text('name', '名称')->rules("required");
  5. $form->select('city_id','城市')->options(
  6. DealCityModel::selectOptionsNoRoot()
  7. )->load('pid', 'district')->loadOne('pid', 'district');//load方法是框架自带的,定义在vendor=>encore=>laravel-admin=>src=>Form=>Field=>Select文件中,loadone是自己写的,在后面会给出代码district为自己定义的方法,pid是根据城市的变化而变化的下拉列表框名称,也就是下面这个。
  8. $form->select('pid','地区')->options(array(0 =>'请选择地区'));
  9. });
  10. }

在from方法后面新建一个district方法

  1. public function district(Request $request)
  2. {
  3. $cityId = $request->get('q');
  4. $list = AreaModel::where(['city_id' => $cityId, 'pid' => 0])->get(['id', DB::raw('name as text')]);
  5. foreach ($list as $key => $value) {
  6. $arr[] = array("id" => $value->id, "text" => $value->text);
  7. }
  8. return $arr;//返回数组到地区的option
  9. }

在vendor=>encore=>laravel-admin=>src=>Form=>Field=>Select文件里load方法后新建一个方法命名为loadone,代码如下:

  1. public function loadOne($field, $sourceUrl, $idField = 'id', $textField = 'text')
  2. {
  3. if (Str::contains($field, '.')) {
  4. $field = $this->formatName($field);
  5. $class = str_replace(['[', ']'], '_', $field);
  6. } else {
  7. $class = $field;
  8. }
  9. $script = <<<EOT
  10. $(function(){
  11. var target = $(".$class");
  12. $.get("$sourceUrl?q="+$("{$this->getElementClassSelector()}").val(), function (data) {
  13. target.find("option").remove();
  14. $(target).select2({
  15. data: $.map(data, function (d) {
  16. d.id = d.$idField;
  17. d.text = d.$textField;
  18. return d;
  19. })
  20. });
  21. });
  22. });
  23. EOT;
  24. Admin::script($script);
  25. return $this;
  26. }

其实就是相当于给load方法增加了一个默认时的数据填充。

最后,千万别忘记在路由上加上district方法哈,要把定义district的路由写在上面→

laravel-admin的多级联动方法

以上这篇laravel-admin多级联动方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

原文链接:https://blog.csdn.net/qq_33541033/article/details/78707250

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 laravel-admin的多级联动方法 https://www.kuaiidc.com/71169.html

相关文章

发表评论
暂无评论