thinkphp5使用無(wú)限極分類(lèi)
本文實(shí)例為大家分享了thinkphp5使用無(wú)限極分類(lèi)的具體代碼,供大家參考,具體內(nèi)容如下
1. 先根據(jù)普通遞歸完成無(wú)限極分類(lèi)
2. 再根據(jù)分號(hào)的類(lèi)的level 添加字符,再次存入數(shù)組的_name字段,最后按照_name字段輸出
/** * 獲得樹(shù)狀數(shù)據(jù) * @param $data 數(shù)據(jù) * @param $title 數(shù)據(jù)庫(kù)中字段名 * @param string $fieldPri 數(shù)據(jù)庫(kù)中主鍵id * @param string $fieldPid 數(shù)據(jù)庫(kù)中父id * @return array */ static public function tree($data, $title, $fieldPri = 'cid', $fieldPid = 'pid') { if (!is_array($data) || empty($data)) return array(); $arr = Data::channelList($data); foreach ($arr as $k => $v) { $str = ""; if ($v['_level'] > 2) { for ($i = 1; $i < $v['_level'] - 1; $i++) { $str .= "│ "; } } if ($v['_level'] != 1) { $t = $title ? $v[$title] : ""; if (isset($arr[$k + 1]) && $arr[$k + 1]['_level'] >= $arr[$k]['_level']) { $arr[$k]['_name'] = $str . "├─ " . $v['_html'] . $t; } else { $arr[$k]['_name'] = $str . "└─ " . $v['_html'] . $t; } } else { $arr[$k]['_name'] = $v[$title]; } } //設(shè)置主鍵為$fieldPri $data = array(); foreach ($arr as $d) { $data[$d[$fieldPri]] = $d; } return $data; }
/** * 獲得所有子欄目 * @param $data 欄目數(shù)據(jù) * @param int $pid 操作的欄目 * @param string $html 欄目名前字符 * @param string $fieldPri 表主鍵 * @param string $fieldPid 父id * @param int $level 等級(jí) * @return array */ static public function channelList($data, $pid = 0, $html = " ", $fieldPri = 'cid', $fieldPid = 'pid', $level = 1) { $data = self::_channelList($data, $pid, $html, $fieldPri, $fieldPid, $level); if (empty($data)) return $data; foreach ($data as $n => $m) { if ($m['_level'] == 1) continue;//結(jié)束單次循環(huán) $data[$n]['_first'] = false; $data[$n]['_end'] = false; if (!isset($data[$n - 1]) || $data[$n - 1]['_level'] != $m['_level']) { $data[$n]['_first'] = true; } if (isset($data[$n + 1]) && $data[$n]['_level'] > $data[$n + 1]['_level']) { $data[$n]['_end'] = true; } } //更新key為欄目主鍵 $category=array(); foreach($data as $d){ $category[$d[$fieldPri]]=$d; } return $category; }
//只供channelList方法使用 /** * 獲得所有子欄目 * @param $data 欄目數(shù)據(jù) * @param int $pid 操作的欄目 * @param string $html 欄目名前字符 * @param string $fieldPri 表主鍵 * @param string $fieldPid 父id * @param int $level 等級(jí) * @return array */ static private function _channelList($data, $pid = 0, $html = " ", $fieldPri = 'cid', $fieldPid = 'pid', $level = 1) { if (empty($data)) return array(); $arr = array(); foreach ($data as $v) { $id = $v[$fieldPri]; if ($v[$fieldPid] == $pid) { $v['_level'] = $level; $v['_html'] = str_repeat($html, $level - 1); $arr[] = $v; $tmp = self::_channelList($data, $id, $html, $fieldPri, $fieldPid, $level + 1); $arr = array_merge($arr, $tmp);//array_merge把兩個(gè)數(shù)組整合為一個(gè)數(shù)組 } } return $arr; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- php無(wú)限極分類(lèi)實(shí)現(xiàn)的兩種解決方法
- PHP超牛逼無(wú)限極分類(lèi)生成樹(shù)方法
- php無(wú)限極分類(lèi)遞歸排序?qū)崿F(xiàn)方法
- php 無(wú)限極分類(lèi)
- PHP實(shí)現(xiàn)無(wú)限極分類(lèi)生成分類(lèi)樹(shù)的方法
- php通過(guò)前序遍歷樹(shù)實(shí)現(xiàn)無(wú)需遞歸的無(wú)限極分類(lèi)
- PHP無(wú)限極分類(lèi)函數(shù)的實(shí)現(xiàn)方法詳解
- 深入淺析PHP無(wú)限極分類(lèi)的案例教程
- php實(shí)現(xiàn)smarty模板無(wú)限極分類(lèi)的方法
- 淺談PHP無(wú)限極分類(lèi)原理
- PHP實(shí)現(xiàn)無(wú)限極分類(lèi)的兩種方式示例【遞歸和引用方式】
- php無(wú)限極分類(lèi)實(shí)現(xiàn)方法分析
相關(guān)文章
PHP實(shí)現(xiàn)的多彩標(biāo)簽效果代碼分享
這篇文章主要介紹了PHP實(shí)現(xiàn)的多彩標(biāo)簽效果代碼分享,經(jīng)??梢钥吹揭恍┎┛椭械臉?biāo)簽(TAGS)頁(yè)面是彩色的效果展現(xiàn),本文就給出了實(shí)現(xiàn)這個(gè)功能的PHP代碼,需要的朋友可以參考下2014-08-08PHP兩個(gè)n位的二進(jìn)制整數(shù)相加問(wèn)題的解決
這篇文章主要為大家詳細(xì)介紹了PHP兩個(gè)n位的二進(jìn)制整數(shù)相加問(wèn)題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08PHP解密支付寶小程序的加密數(shù)據(jù)、手機(jī)號(hào)的示例代碼
這篇文章主要介紹了PHP解密支付寶小程序的加密數(shù)據(jù)、手機(jī)號(hào)的示例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02PHP+javascript制作帶提示的驗(yàn)證碼源碼分享
經(jīng)??吹膭e人網(wǎng)站上輸完驗(yàn)證碼,可以直接判斷正確與否,感覺(jué)體驗(yàn)非常不錯(cuò),趕緊給自己網(wǎng)站也加上,源碼分享給大家2014-05-05Yii2使用小技巧之通過(guò) Composer 添加 FontAwesome 字體資源
前天幫同事改個(gè)十年前的網(wǎng)站 bug,頁(yè)面上一堆 include require 不禁讓人抱頭痛哭??吹?V2EX 上的討論說(shuō),寫(xiě) PHP 不用框架等同于耍流氓。Yii Framework 是我使用了 2 年多的 PHP 框架,器大活好,皮實(shí)耐操。 Yii2 還在 Beta 中,不過(guò)不影響拿來(lái)預(yù)研。2014-06-06