|
導讀網頁的本質就是超級文本標記語言,通過結合使用其他的Web技術(如:腳本語言、公共網關接口、組件等),可以創造出功能強大的網頁。因而,超級文本標記語言是萬維網(Web)編程的基礎,也就是說萬維網是建立... 網頁的本質就是超級文本標記語言,通過結合使用其他的Web技術(如:腳本語言、公共網關接口、組件等),可以創造出功能強大的網頁。因而,超級文本標記語言是萬維網(Web)編程的基礎,也就是說萬維網是建立在超文本基礎之上的。超級文本標記語言之所以稱為超文本標記語言,是因為文本中包含了所謂“超級鏈接”點。 本篇文章給大家帶來的內容是介紹php如何實現無限極分類?無限極分類的三種實現方法(代碼詳解)。有一定的參考價值,有需要的朋友可以參考一下,希望對你們有所幫助。無限極分類1: public function judeg($id)
{
$rs = Db::name('finance_class') -> field('parent_code') -> where('id',$id) -> select();
$i = 1;
foreach($rs as $k => $v){
if($v['parent_code'] <> 0){
$i += $this -> judeg($v['parent_code']);
}
}
return $i;
}
public function cid($id,$pid)
{
$w['parent_code'] = $id;
$rs = Db::name('finance_class')
-> field('id,code,name,parent_code')
-> where($w)
-> order('code asc')
-> select();
$str = '';
foreach ($rs as $k => $v) {
$name = $v['name'];
$_id = $v['id'];
$cutOff = '';
for($i = 0; $i < $this -> judeg($_id); $i++){
$cutOff.='-';
}
if($_id == $pid){
$str.='<p>他的id='.$_id.'====他的級別'.$cutOff.$name.'</p>';
}else{
$str.='<p>他的id='.$_id.'====他的級別'.$cutOff.$name.'</p>';
}
$str.=$this->cid($_id,$pid);
}
return $str;
37}
public function finance_c()
{
$w['type'] = '資產類';
$w['parent_code'] = 0;
$rs = Db::name('finance_class')
-> field('id,code,name,parent_code')
-> where($w)
-> select();
$str = '';
foreach ($rs as $k => $v){
$str.= '<p>一級name:'.$v['name'].'</p>';
$str.= $this -> cid($v['id'],0);
}
echo $str;
}這個方法出來的效率慢,而且很繞。 方法2: public function getVoucherClass()
{
$lists = Db::name('finance_class')->select();
$lists = $this->getTree($lists);
foreach($lists as $value){
echo str_repeat('--', $value['level']), $value['name'].'<br />';
}
10}
/**
* 遞歸實現無限極分類
* @param $array 分類數據
* @param $pid 父ID
* @param $level
* @return $list
*/
function getTree($array, $pid =0, $level = 0){
static $list = [];
foreach ($array as $key => $value){
if ($value['parent_code'] == $pid){
$value['level'] = $level;
$list[] = $value;
unset($array[$key]);
$this->getTree($array, $value['id'],$level+1);
}
}
return $list;
30}無限極分類3: public function index()
{
$lists = \think\Db::table('ozyx_finance_class')->select();
$lists = $this->getTree($lists,0);
foreach ($lists as $k => $v) {
$lists_one[$v['type']][]=$v;
}
// halt($lists_one);
$this->assign('lists', $lists_one);
return view();
}
/**
* 無限極分類
*/
function getTree($data, $pid)
{
$tree = '';
foreach($data as $k => $v)
{
if($v['parent_code'] == $pid)
{
$v['parent_code'] = $this->getTree($data, $v['id']);
$tree[] = $v;
unset($data[$k]);
}
}
return $tree;
}數據表結構:
以上就是php如何實現無限極分類?無限極分類的三種實現方法(代碼詳解)的詳細內容,更多請關注php中文網其它相關文章! 網站建設是一個廣義的術語,涵蓋了許多不同的技能和學科中所使用的生產和維護的網站。 |
溫馨提示:喜歡本站的話,請收藏一下本站!