laravel-admin的多级联动⽅法
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.$textField;
return d;
})
});
});
});
EOT;
Admin::script($script);
return $this;
}
其实就是相当于给load⽅法增加了⼀个默认时的数据填充。
最后,千万别忘记在路由上加上district⽅法哈,要把定义district的路由写在上⾯→
laravel框架下载以上这篇laravel-admin的多级联动⽅法就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论