时间:2021-05-25
用yii框架做了一个无限极分类,主要的数组转换都是粘贴的别人的代码,但还是不要脸的写出来,方便以后自己看
用的是递归,不是path路径
控制器:
protected function subtree($arr,$id=0,$lev=1){ $subs = array(); // 子孙数组 foreach($arr as $v) { if($v['parent_id'] == $id) { $v['lev'] = $lev; $subs[] = $v; // 举例说找到array('id'=>1,'name'=>'安徽','parent'=>0), $subs = array_merge($subs,$this->subtree($arr,$v['cat_id'],$lev+1)); } } return $subs; }public function actionCreate() { $model = new EcsCategory(); $query = new \yii\db\Query(); $query->select('*') ->from('ecs_category'); $command = $query->createCommand(); $res=$command->queryAll(); $tree = $this->subtree($res,0,1); foreach($tree as $k=> $v) { $tree[$k]['new_cat_name']=str_repeat('--',$v['lev']).$v['cat_name'].str_repeat('--',$v['lev']); //str_repeat — 重复一个字符串 } $arr=array( 'new_cat_name'=>'顶级分类', 'cat_id'=>0 ); array_unshift($tree,$arr); if ($model->load(Yii::$app->request->post()) && $model->save()) { return $this->redirect(['view', 'id' => $model->cat_id]); } else { return $this->render('create', [ 'model' => $model, 'data'=>$tree, ]); } }视图:
use \yii\helpers\ArrayHelper;<?= $form->field($model, 'parent_id')->dropDownList(ArrayHelper::map($data,'cat_id','new_cat_name') ,['prompt' => '请选择父级分类']) ?>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了php无限极分类实现方法。分享给大家供大家参考,具体如下:今天给大家带来的是php的无限极分类技术,本人把无限极分类划分为两种。首先我把数据库表给
平时开发中或多或少不可避免会遇到无限极分类的问题,因为效率、逻辑等问题也一直使这类问题比较尖锐。今天我们以yii2框架为基础,栏目无限极为例,对这个问题进行一个
本文实例讲述了php通过前序遍历树实现无需递归的无限极分类。分享给大家供大家参考。具体如下:大家通常都是使用递归实现无限极分类都知道递归效率很低,下面介绍一种改
本文实例讲述了PHP实现无限极分类的两种方式。分享给大家供大家参考,具体如下:面试的时候被问到无限极分类的设计和实现,比较常见的做法是在建表的时候,增加一个PI
本文实例讲述了php无限极分类递归排序实现方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:functionorder($array,$pid=0