laravel-admin的多级联动方法


Posted in PHP onSeptember 30, 2019

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.text = d.$textField;
    return d;
   })
  });
 });
});
EOT;

  Admin::script($script);

  return $this;
 }

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

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

laravel-admin的多级联动方法

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

PHP 相关文章推荐
聊天室php&amp;mysql(四)
Oct 09 PHP
php 学习资料零碎东西
Dec 04 PHP
php去除换行(回车换行)的三种方法
Mar 26 PHP
从零开始学YII2框架(四)扩展插件yii2-kartikgii
Aug 20 PHP
php官方微信接口大全(微信支付、微信红包、微信摇一摇、微信小店)
Dec 21 PHP
php防止sql注入的方法详解
Feb 20 PHP
PHP截取发动短信内容的方法
Jul 04 PHP
PHP编程实现的TCP服务端和客户端功能示例
Apr 13 PHP
PHP排序算法之基数排序(Radix Sort)实例详解
Apr 21 PHP
swoole_process实现进程池的方法示例
Oct 29 PHP
php多进程模拟并发事务产生的问题小结
Dec 07 PHP
thinkphp5 + ajax 使用formdata提交数据(包括文件上传) 后台返回json完整实例
Mar 02 PHP
php更新cookie内容的详细方法
Sep 30 #PHP
使用laravel的migrate创建数据表的方法
Sep 30 #PHP
Yii2.0框架behaviors方法使用实例分析
Sep 30 #PHP
php解决约瑟夫环算法实例分析
Sep 30 #PHP
php使用curl伪造浏览器访问操作示例
Sep 30 #PHP
laravel-admin 在列表页添加自定义按钮的例子
Sep 30 #PHP
Laravel框架控制器的request与response用法示例
Sep 30 #PHP
You might like
PHP正确解析UTF-8字符串技巧应用
2012/11/07 PHP
PHP ? EasyUI DataGrid 资料取的方式介绍
2012/11/07 PHP
ThinkPHP结合ajax、Mysql实现的客户端通信功能代码示例
2014/06/23 PHP
PHP版本升级到7.x后wordpress的一些修改及wordpress技巧
2015/12/25 PHP
PHPStrom 新建FTP项目以及在线操作教程
2016/10/16 PHP
php类自动装载、链式操作、魔术方法实现代码
2017/07/23 PHP
基于PHP的微信公众号的开发流程详解
2020/08/07 PHP
新手入门常用代码集锦
2007/01/11 Javascript
锋利的jQuery 要点归纳(二) jQuery中的DOM操作(下)
2010/03/23 Javascript
setinterval()与clearInterval()JS函数的调用方法
2015/01/21 Javascript
使用jquery+CSS3实现仿windows10开始菜单的下拉导航菜单特效
2015/09/24 Javascript
jquery实现点击弹出可放大居中及关闭的对话框(附demo源码下载)
2016/05/10 Javascript
javascript实现页面滚屏效果
2017/01/17 Javascript
jquery 判断是否支持Placeholder属性的方法
2017/02/07 Javascript
100多个基础常用JS函数和语法集合大全
2017/02/16 Javascript
详解滑动穿透(锁body)终极探索
2019/04/16 Javascript
[45:59]EG vs OG 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
Java多线程编程中ThreadLocal类的用法及深入
2016/06/21 Python
20招让你的Python飞起来!
2016/09/27 Python
Django自定义分页与bootstrap分页结合
2021/02/22 Python
Python Json序列化与反序列化的示例
2018/01/31 Python
python对列进行平移变换的方法(shift)
2019/01/10 Python
Pyqt5如何让QMessageBox按钮显示中文示例代码
2019/04/11 Python
CSS3制作炫酷带方向感应的鼠标滑过图片3D动画
2016/03/16 HTML / CSS
HTML5新增加的功能详解
2016/09/05 HTML / CSS
惠普加拿大在线商店:HP加拿大
2017/09/15 全球购物
澳大利亚手表品牌:Time IV Change
2018/10/06 全球购物
Mountain Warehouse德国官网:英国户外零售商
2019/08/11 全球购物
The North Face北面荷兰官网:美国著名户外品牌
2019/10/16 全球购物
迪士尼法国在线商店:shopDisney FR
2020/12/03 全球购物
2019史上最全Database工程师题库
2015/12/06 面试题
革命先烈的英雄事迹材料
2014/02/15 职场文书
护理心得体会范文
2016/01/22 职场文书
Python Parser的用法
2021/05/12 Python
详解Vue router路由
2021/11/20 Vue.js
MySQL详解进行JDBC编程与增删改查方法
2022/06/16 MySQL