整合layui+tp5.1时,有时候需要调用栏目数,这就需要进行数据的动态化调用,之前试过很多种方法,都没有生效,后面查看了js数据调用的方法,结合layui进行多次尝试,终于找出了能够实现这一功能的方法,希望对大家有用。
以下的例子是一个调用城市的实例,数据库字段包括:id,order(排序),pid(上级城市ID)、name(城市名称),这里包含了省级、市级、县/区级三级城市。
第一步:根据Layui给出的方法,首先写出HTML页面,如下所示:
其中___ADMIN__是你自己配置的样式路径,修改成自己的路径即可。另外由于这里调用数据采用的是js数据调用,所以需要加载jquery库,我这里用的是jquery-3.2.1,大家可以根据自己的实际需求加载对应版本的jquery库,这里不多说,直接上代码:
【HTML】
Title
第二步:书写后台PHP代码,这里我是根据TP5.1 的规则书写的代码
修正说明:1,实现真正的软件开源。2,安装界面的美化3,真正实现栏目的递归无限极分类。4,后台添加幻灯片图片的管理,包括添加,修改,删除等。5,修正添加新闻的报错信息6,修正网站参数的logo上传问题7,修正产品图片的栏目无限极分类8,修正投票系统的只能单选问题9,添加生成静态页功能10,添加缓存功能特点和优势1. 基于B/S架构,通过本地电脑、局域网、互联网皆可使用,使得企业的管理与业务不受地域
【PHP代码】
//获取栏目信息
public function getCategoryList(){
$id = Request::param('id');
$parentId = $this->getAllParentId($id);//获取父级ID信息
$list = AreaModel::where('pid',100000)
->where('status',0)
->order('order asc')
->select();
$cate = array();
foreach ($list as $key=>$v){
$cate[$key]['title'] = $v['name'];
if(in_array($v['id'],$parentId)){
$cate[$key]['checked'] = 'true';
$cate[$key]['spread'] = 'true';
}
$cate[$key]['field'] = 'name'.$v['id'];
$cate[$key]['id'] = $v['id'];
$cate[$key]['href'] = "/yejuzhi/article/index?cid=".$v['id'];
$child = AreaModel::where('pid',$v['id'])
->where('status',0)
->order('order asc')
->select();
if($child){
foreach ($child as $key1=>$c){
/*$cate[$key]['children'][] = array(
'title' => $c['c_name'],
'id' => $c['id'],
'href' => "/yejuzhi/article/index?cid=".$c['id'],
'children' => array()
);*/
$cate[$key]['children'][$key1]['title'] = $c['name'];
$cate[$key]['children'][$key1]['checked'] = 'true';
$cate[$key]['children'][$key1]['spread'] = 'true';
$cate[$key]['children'][$key1]['field'] = 'name'.$c['id'];
$cate[$key]['children'][$key1]['id'] = $c['id'];
$cate[$key]['children'][$key1]['href'] = '';
$child1 = AreaModel::where('pid',$c['id'])
->where('status',0)
->order('order asc')
->select();
foreach ($child1 as $key2=>$value){
$cate[$key]['children'][$key1]['children'][$key2]['title'] = $value['name'];
$cate[$key]['children'][$key1]['children'][$key2]['checked'] = 'true';
$cate[$key]['children'][$key1]['children'][$key2]['spread'] = 'true';
$cate[$key]['children'][$key1]['children'][$key2]['field'] = 'name'.$value['id'];
$cate[$key]['children'][$key1]['children'][$key2]['id'] = $value['id'];
$cate[$key]['children'][$key1]['children'][$key2]['href'] = '';
}
}
}
//$cate[$key]['children'][] = array();
}
//dump($cate);
return json_encode($cate);
}在上面用到了一个方法:getAllParentId,这个方法是专门用来获取所有父级ID的方法,下面是代码信息:
//获取父级栏目
public function getAllParentId($id = 43){
static $parentId;
$cates = AreaModel::where('id',$id)->find();
if($cates['pid']==0){
$parentId[] = $cates['id'];
}
$list = AreaModel::where('status',0)
->order('order asc')
->select();
foreach ($list as $k => $v) {
if ($cates['pid'] == $v['id']) {
$parentId[] = $v['id'];
$this->getAllParentId($v['id']);
}
}
return $parentId;
}大家可以试一下,希望能够给与大家帮助。我这里是对城市信息的循环输出,大家也可以尝试进行其他信息的输出,只需要修改数据调用规则即可,但是需要注意的是,不管如何调用父级、子级是必须要存在的。
谢谢!
相关推荐:最新的10个thinkphp视频教程









