php+mysql實現(xiàn)的無限分類方法類定義與使用示例
本文實例講述了php+mysql實現(xiàn)的無限分類方法類定義與使用。分享給大家供大家參考,具體如下:
創(chuàng)建數(shù)據(jù)庫以及表
CREATE DATABASE `sortclass`DEFAULT CHARSET utf8; CREATE TABLE IF NOT EXISTS `class` ( `cid` mediumint(8) unsigned NOT NULL auto_increment, `pid` mediumint(8) unsigned NOT NULL, `cname` varchar(50) NOT NULL, PRIMARY KEY (`cid`), KEY `pid` (`pid`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
header("Content-type: text/html; charset=utf-8"); //連接數(shù)據(jù)庫 $link = mysql_connect('localhost','root','eric') or die(mysql_error()); mysql_select_db('sortclass',$link); //無限分類類庫 class SortClass{ var $data = array(); var $child = array(-1=>array()); var $layer = array(-1=>-1); var $parent = array(); var $link; var $table; function SortClass($link, $table){ $this->setNode(0, -1, '頂極節(jié)點'); $this->link = $link; $this->table = $table; $node = array(); $results = mysql_query('select * from '.$this->table.'',$this->link); while($node = mysql_fetch_assoc($results)){ $this->setNode($node['cid'],$node['pid'],$node['cname']); } } function setNode ($id, $parent, $value){ $parent = $parent?$parent:0; $this->data[$id] = $value; $this->child[$id] = array(); $this->child[$parent][] = $id; $this->parent[$id] = $parent; $this->layer[$id] = !isset($this->layer[$parent])? 0 : $this->layer[$parent] + 1; } function getList (&$tree, $root= 0){ foreach ($this->child[$root] as $key=>$id){ $tree[] = $id; if ($this->child[$id]) $this->getList($tree, $id); } } function getValue ($id){return $this->data[$id];} function getLayer ($id, $space = false){ return $space?str_repeat($space, $this->layer[$id]):$this->layer[$id]; } function getParent ($id){return $this->parent[$id];} function getParents ($id){ while ($this->parent[$id] != -1){ $id = $parent[$this->layer[$id]] = $this->parent[$id]; } ksort($parent); reset($parent); return $parent; } function getChild ($id){return $this->child[$id];} function getChilds ($id = 0){ $child = array($id); $this->getList($child, $id); return $child; } function addNode($name,$pid){ mysql_query("insert into $this->table (`pid`,`cname`) values ('$pid','$name')",$this->link); } function modNode($cid, $newName){ mysql_query("update $this->table set `cname`='$newName' where `cid` = $cid",$this->link); } function delNode($cid){ $allChilds = $this->getChilds($cid); $sql =''; if(empty($allChilds)){ $sql = "delete from $this->table where `cid` = $cid"; }else{ $sql = 'delete from '.$this->table.' where `cid` in ('.implode(',',$allChilds).','.$cid.')'; } mysql_query($sql,$this->link); } function moveNode($cid, $topid){ mysql_query("update $this->table set `pid`=$topid where `cid` = $cid", $this->link); } } //函數(shù) function back(){ echo '<script language="JavaScript">window.location.href="test.php?" rel="external nofollow" +new Date().getTime();</script>'; exit; } //聲成select function makeSelect($array,$formName){ global $tree; $select = '<select name="'.$formName.'">'; foreach ($array as $id){ $select.='<option value="'.$id.'">'.$tree->getLayer($id, '|-').$tree->getValue($id)."</option>"; } return $select.'</select>'; } $tree = new SortClass($link,'`class`'); $op = !empty($_POST['op']) ? $_POST['op'] : $_GET['op']; if(!empty($op)){ if($op=='add'){ $tree->addNode($_POST['cname'],$_POST['pid']); back(); } if($op=='mod'){ $tree->modNode($_POST['cid'],$_POST['cname']); back(); } if($op=='del'){ $tree->delNode($_GET['cid']); back(); } if($op=='move'){ $tree->moveNode($_POST['who'],$_POST['to']); back(); } } $category = $tree->getChilds(); ?> <style type="text/css"> body{font-size:12px;} ul{list-style:none;} a{cursor:pointer;} </style> <script language="javascript"> function $(e){return document.getElementById(e);} function mod(cid){ $('cid').value=cid; $('op').value='mod'; $('name').style.border='1px solid red'; } </script> <form action="test.php" method="post"> 名稱:<input type="text" id="name" name="cname" /> 添加到:<?=makeSelect($category,'pid')?><br /> <input type="hidden" id="op" name="op" value="add" /> <input type="hidden" id="cid" name="cid" /> <input type="submit" value="Submit" /> </form> <h3>移動分類</h3> <form action="test.php" method="post"> <?=makeSelect($category,'who')?>移動到:<?=makeSelect($category,'to')?> <input type="hidden" id="op" name="op" value="move" /> <input type="submit" value="Submit" /> </form> <ul> <?php foreach ($category as $id){ echo '<li>'.$tree->getLayer($id, '|- ').$tree->getValue($id).' <a href="test.php?op=del&cid='.$id.'" rel="external nofollow" >Del</a> <a onclick="mod('.$id.')">Edit</a> </li>'; } ?> </ul>
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+mysql數(shù)據(jù)庫操作入門教程》、《php+mysqli數(shù)據(jù)庫程序設(shè)計技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
- PHP+Mysql樹型結(jié)構(gòu)(無限分類)數(shù)據(jù)庫設(shè)計的2種方式實例
- php+mysql實現(xiàn)無限分類實例詳解
- 實現(xiàn)PHP+Mysql無限分類的方法匯總
- php+mysql數(shù)據(jù)庫實現(xiàn)無限分類的方法
- php+mysql實現(xiàn)無限級分類 | 樹型顯示分類關(guān)系
- php+mysql查詢實現(xiàn)無限下級分類樹輸出示例
- php+mysql不用遞歸實現(xiàn)的無限級分類實例(非遞歸)
- php+mysql實現(xiàn)無限級分類
- PHP遞歸寫入MySQL實現(xiàn)無限級分類數(shù)據(jù)操作示例
相關(guān)文章
php實現(xiàn)阿拉伯?dāng)?shù)字和羅馬數(shù)字相互轉(zhuǎn)換的方法
這篇文章主要介紹了php實現(xiàn)阿拉伯?dāng)?shù)字和羅馬數(shù)字相互轉(zhuǎn)換的方法,涉及php字符串操作的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-04-04PHP實現(xiàn)無限極分類的兩種方式示例【遞歸和引用方式】
這篇文章主要介紹了PHP實現(xiàn)無限極分類的兩種方式,結(jié)合實例形式分析了php基于遞歸和引用方式進(jìn)行數(shù)組遍歷的相關(guān)操作技巧,需要的朋友可以參考下2019-03-03golang與php實現(xiàn)計算兩個經(jīng)緯度之間距離的方法
這篇文章主要介紹了golang與php實現(xiàn)計算兩個經(jīng)緯度之間距離的方法,結(jié)合實例形式對比分析了Go語言與php進(jìn)行經(jīng)緯度計算的相關(guān)數(shù)學(xué)運算技巧,需要的朋友可以參考下2016-07-07php從數(shù)組中隨機選擇若干不重復(fù)元素的方法
這篇文章主要介紹了php從數(shù)組中隨機選擇若干不重復(fù)元素的方法,涉及php數(shù)組操作的相關(guān)常用技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03php mysql實現(xiàn)mysql_select_db選擇數(shù)據(jù)庫
在PHP中,與MySQL服務(wù)器建立連接后,需要確定所要連接的數(shù)據(jù)庫,此時我們可以使用mysql_select_db函數(shù),該函數(shù)用于選擇需要操作的數(shù)據(jù)庫,需要的朋友可以參考下2016-12-12php使用mysqli向數(shù)據(jù)庫添加數(shù)據(jù)的方法
這篇文章主要介紹了php使用mysqli向數(shù)據(jù)庫添加數(shù)據(jù)的方法,實例分析了php使用mysqli進(jìn)行數(shù)據(jù)庫操作的技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03