使用yii框架怎么实现一个无限极分类?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
控制器:
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' => '请选择父级分类']) ?>
关于使用yii框架怎么实现一个无限极分类问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。