色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

php+mysql實(shí)現(xiàn)的無限分類方法類定義與使用示例

瀏覽:102日期:2022-09-10 10:28:09

本文實(shí)例講述了php+mysql實(shí)現(xiàn)的無限分類方法類定義與使用。分享給大家供大家參考,具體如下:

創(chuàng)建數(shù)據(jù)庫(kù)以及表

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ù)庫(kù)$link = mysql_connect(’localhost’,’root’,’eric’) or die(mysql_error());mysql_select_db(’sortclass’,$link);//無限分類類庫(kù)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é)點(diǎn)’); $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='http://m.lshqa.cn/bcjs/test.php?' rel='external nofollow' +new Date().getTime();</script>’; exit;}//聲成selectfunction 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' name='cname' /> 添加到:<?=makeSelect($category,’pid’)?><br /> <input type='hidden' name='op' value='add' /> <input type='hidden' name='cid' /> <input type='submit' value='Submit' /> </form> <h3>移動(dòng)分類</h3> <form action='test.php' method='post'> <?=makeSelect($category,’who’)?>移動(dòng)到:<?=makeSelect($category,’to’)?> <input type='hidden' name='op' value='move' /> <input type='submit' value='Submit' /> </form> <ul><?phpforeach ($category as $id){ echo ’<li>’.$tree->getLayer($id, ’|- ’).$tree->getValue($id).’ <a href='http://m.lshqa.cn/bcjs/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ù)庫(kù)操作入門教程》、《php+mysqli數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 国产最爽的乱淫视频国语对 | 女人张开腿让男人添 | 一级一级 a爱片免费视频 | 亚洲人成综合在线播放 | 亚洲精品成人一区二区www | 亚洲成人高清在线观看 | 亚洲另类激情综合偷自拍 | 国产精品亚洲第一区二区三区 | 亚洲精品日韩中文字幕久久久 | 久久99亚洲精品久久久久网站 | 亚洲欧美日韩另类精品一区二区三区 | 亚欧色 | 91撸视频 | 国产精品露脸脏话对白 | 亚洲欧美日韩精品久久亚洲区色播 | 在线播放一级片 | 日韩欧美在线观看视频一区二区 | 久久思思爱 | 韩国本免费一级毛片免费 | 天天躁夜夜躁狠狠躁2024 | 免费国产成人手机在线观看 | 久久厕所 | 性感美女视频黄.免费网站 性高湖久久久久久久久 | 国产亚洲一路线二路线高质量 | 欧美一区二区视频在线观看 | 性色综合 | 窝窝人体色 | 中文字幕一级毛片 | 99精品偷自拍| 免费国产不卡午夜福在线观看 | 九草视频 | 国产成人高清亚洲一区久久 | 综合在线视频精品专区 | 国产亚洲精品日韩已满十八 | 欧美一级片在线播放 | 日韩欧美国产一区二区三区 | 免费国产在线观看 | 国产露脸3p普通话 | 一级做a爱过程免费视频麻豆 | 91亚洲综合 | 欧美日本在线视频 |