当前位置:首页 > CMS教程 > 其它CMS > 列表

laravel-admin的多级联动方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-12-26 16:14:01 浏览: 评论:0 

今天小编就为大家分享一篇laravel-admin的多级联动方法,具有很好的参考价值,希望对大家有所帮助,一起跟随小编过来看看吧。

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

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

laravel-admin laravel多级联动

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

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

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

  1. protected function form() 
  2.  return Admin::form(AreaModel::classfunction (Form $form) { 
  3.  
  4.   $form->text('name''名称')->rules("required"); 
  5.   $form->select('city_id','城市')->options( 
  6.  
  7.    DealCityModel::selectOptionsNoRoot() 
  8.  
  9.   )->load('pid''district')->loadOne('pid''district'); 

load方法是框架自带的,定义在vendor=>encore=>laravel-admin=>src=>Form=>Field=>Select文件中,loadone是自己写的,在后面会给出代码district为自己定义的方法,pid是根据城市的变化而变化的下拉列表框名称,也就是下面这个。

  1. $form->select('pid','地区')->options(array(0 =>'请选择地区')); 
  2.  
  3.  }); 

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

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

在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.  
  10.   $script = <<
  11. $(function(){ 
  12.  var target = $(".$class"); 
  13.  $.get("$sourceUrl?q="+$("{$this->getElementClassSelector()}").val(), function (data) { 
  14.   target.find("option").remove(); 
  15.   $(target).select2({ 
  16.    data: $.map(data, function (d) { 
  17.     d.id = d.$idField
  18.     d.text = d.$textField
  19.     return d; 
  20.    }) 
  21.   }); 
  22.  }); 
  23. }); 
  24. EOT; 
  25.  
  26.   Admin::script($script); 
  27.  
  28.   return $this
  29.  } 

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

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

laravel-admin laravel多级联动

Tags: laravel-admin laravel多级联动

分享到: