无标题文章

首先创建数据库:

CREATEDATABASEIFNOTEXISTS`fenlei`DEFAULTcharacterSETutf8COLLATEutf8_general_ci;USE`fenlei`;CREATETABLEIFNOTEXISTS`category`(`catid`mediumint(8)unsignedNOTNULLAUTO_INCREMENTCOMMENT'主键',`upid`mediumint(8)unsignedNOTNULLDEFAULT'0'COMMENT'上级分类catid',`catname`varchar(255)NOTNULLDEFAULT''COMMENT'分类名称',`displayorder`tinyint(1)NOTNULLDEFAULT'0'COMMENT'显示顺序',`status`tinyint(1)NOTNULLDEFAULT'0'COMMENT'0-关闭,1-启用',

PRIMARYKEY(`catid`)

)ENGINE=InnoDBDEFAULTCHARSET=utf8COMMENT='文章分类';INSERTINTO`category`VALUES('1','0','分类1','0','1'),

('2','0','分类2','0','1'),

('3','0','分类3','0','1'),

('4','0','分类4','0','1'),

('5','0','分类5','0','1'),

('6','1','分类1-1','0','1'),

('7','1','分类1-2','0','1'),

('8','1','分类1-3','0','1'),

('9','1','分类1-4','0','1'),

('10','1','分类1-5','0','1'),

('11','6','分类1-1-1','0','1'),

('12','6','分类1-1-2','0','1'),

('13','6','分类1-1-3','0','1'),

('14','7','分类1-2-1','0','1'),

('15','7','分类1-2-2','0','1'),

('16','11','分类1-1-1-1','0','1'),

('17','11','分类1-1-1-2','0','1');

model


* 这是一个成熟的模型,放入相应文件夹直接调用即可

*/namespaceapp\index\model;classCategoryextends\think\Model{/*

* 打开冰箱:从数据库取出所有数据,并放进缓存内

* 即可独立输出也可以在其他位置调用

*/publicfunctioncategory_query($catid=0){

cache('category',null);//正式环境删除本行可减少一次查询if(!$result = cache('category')){

$Category =newCategory();

$result = [];foreach($Category->order('displayorder asc,catid asc')->select()as$data){

$result[$data['catid']] = $data;

}

cache('category',$result,0);

}return$catid ? $result[$catid] : $result;//如果传入单个分类catid,那么直接返回就行,可用于列表页,大大降低查询次数}/*

* 把大象放进冰箱:将第一步得到的数据集转化为无限级数组

* 即可独立输出也可以在其他位置调用

*/publicfunctioncategory_tree($upid=0,$status='0,1'){

$status = is_string($status) ? explode(',', $status) : $status;

$result = [];foreach($this->category_query()as$catid=>$cat){if($upid == $cat['upid'] && in_array($cat['status'],$status)){

$cat['subcat'] =$this->category_tree($cat['catid'],$status);

$result[] = $cat;

}

}return$result;

}/*

* 关上冰箱门:用于实际用途,将多级数据传入,转化为前端html代码

* 该html的转化结果可从第一步中获取方式不同来实现从哪一级开始展示

* 本函数只是师范函数,实际运用中只需要修改这个函数结构体就能完全实现仿网易盖楼效果

*/publicfunctioncategory_html($categorys,$depth=0){

$depth_html = $html ='';for($i=0; $i < $depth; $i++) {

$depth_html .='——';

}foreach($categorysas$data){

'.$data['catid'].'

'.$data['displayorder'].'

'.$depth_html.$data['catname'].'

$html .='';if($data['subcat']){

$html .=$this->category_html($data['subcat'],$depth+1);

}

}return$html;

}

}?>



首先通过category_query方法获取到所有分类,

然后通过category_tree方法将得到的数据转化为无限分类数组

最后再通过category_html方法将上面得到的无限分类数组输出为html

控制器Controller


$Category =newCategory;//实例化类$category_tree = $Category->category_tree();// 获取整体多级数组树结果$this->view->category_list = $Category->category_html($category_tree);//将结果转化为实体html并传值给模板return$this->fetch();

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,110评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,443评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,474评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,881评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,902评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,698评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,418评论 3 419
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,332评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,796评论 1 316
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,968评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,110评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,792评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,455评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,003评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,130评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,348评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,047评论 2 355

推荐阅读更多精彩内容

  • # 一度蜜v3.0协议 --- # 交互协议 [TOC] ## 协议说明 ### 请求参数 下表列出了v3.0版协...
    c5e350bc5b40阅读 650评论 0 0
  • 转至元数据结尾创建: 董潇伟,最新修改于: 十二月 23, 2016 转至元数据起始第一章:isa和Class一....
    40c0490e5268阅读 1,720评论 0 9
  • http://blog.csdn.net/david21984/article/details/57451917 ...
    紫色冰雨阅读 299评论 0 1
  • 1、设置UILabel行间距 NSMutableAttributedString*attrString=[[NSM...
    iOS祎阅读 2,166评论 0 0
  • 河岸上有一棵苍老的柳树 那是我太爷爷种下的 当年他放羊的时候 折下的柳枝被他随手插在了河边 当柳枝长成了树的时候 ...
    燕赵大侠阅读 399评论 0 0