php 无限极分类


Posted in PHP onMarch 27, 2008
<?php 
/*======================================================== 
类名:catalog 
功能:无限分级类 
方法: 
树形显示分类 
catalog_show($id) //参数$id 递归调用 
流程:找到父分类为0所有根分类-> 一直递归取得所有分类并显示   
添加分类 
catalog_add($uid,$name) //$uid 父id //$name 分类名   
流程:依据$uid,在此id下添加一个新子id 
删除分类 
catalog_del($uid)//参数 $uid 数要删除的分类 
修改分类 
catalog_set($id,$name) //参数 $id 要修改的分类 //参数 $name 新的分类名 
变量: 
$config //数据库信息-> host,user,pass,dbname 
$catalog_dbname //分类数据库名 
数据库: 
catalog_id //分类的自然序号 
catalog_uid //分类的父分类 
catalog_name //分类名 
catalog_path_number //亲缘树数字形式 0:1:2 
catalog_path_char //亲缘树字符形式 分类1:分类1.1:分类1.1.1 
参照文章 http://www.phpchina.com/12823/viewspace_4468.html 
========================================================*/ 
class catalog{ 
var $config; 
var $catalog_dbname; 
var $links; 
private function connect(){ 
$this->links = mysql_connect($this->config['host'],$this->config['user'],$this->config['pass']) or die("错误: 第".__LINE__."行<br>".mysql_error()); 
mysql_select_db($this->config['dbname'],$this->links); 
mysql_query("SET NAMES gb2312"); 
} 
function catalog_show($uid = 0){ 
$this->connect(); 
$sql = "Select * FROM ".$this->catalog_dbname. " 
Where catalog_uid = ". $uid ." 
orDER BY catalog_id "; 
$result = mysql_query($sql,$this->links) or die("错误: 第".__LINE__."行<br>".mysql_error()); 
if(mysql_num_rows($result) > 0){ 
while ($row = mysql_fetch_assoc($result)){   
if($this->sun_catalog($row['catalog_id'])){//判断有没有子分类 
$cata_img = "<img id = 'img".$row['catalog_id']."' src='./img/last_node.jpg' ōnclick='click_catalog(".$row['catalog_id'].")'/>"; 
}else{ 
$cata_img = "<img src='./img/sp.jpg'/>"; 
} 
$path = explode(":",$row['catalog_path_number']); 
if(count($path) > 1){ 
for($i=1;$i<count($path);$i++){ 
$path_img .= "<img src='./img/sp.jpg'/>"; 
} 
} 
echo $path_img.$cata_img; 
echo "<a class='menu' href = 'javascrīpt:send_id(".$row['catalog_id'].")'>"; 
echo $row['catalog_name']."</a><br>"; 
$path_img = ""; 
if($this->sun_catalog($row['catalog_id'])){   
$hidden_div = "style='display:none'";   
echo "<div id = 'div".$row['catalog_id']."' ".$hidden_div.">";   
$this->catalog_show($row['catalog_id']); 
echo "</div>"; 
}   
} 
}   
} 
private function sun_catalog($uid){//判断是否有子分类 
$sql = "Select * FROM ".$this->catalog_dbname. " 
Where catalog_uid = ". $uid ." 
orDER BY catalog_id "; 
$result = mysql_query($sql,$this->links) or die("错误: 第".__LINE__."行<br>".mysql_error()); 
if(mysql_num_rows($result) > 0){ 
return true; 
}else{ 
return false; 
} 
} 
function catalog_add($uid,$name){ 
//获取父id的亲缘树 
$this->connect(); 
$sql = "Select * FROM ".$this->catalog_dbname." 
Where catalog_id = '".$uid."'"; 
$result = mysql_query($sql,$this->links) 
or die("错误: 第".__LINE__."行<br>".mysql_error()); 
$row = mysql_fetch_assoc($result); 
$fid_path_number = $row['catalog_path_number'];//id的数字亲缘树 
$fid_path_char = $row['catalog_path_char'];//id的字符亲缘树 
//插入数据 先插入行->再找到最新插入的id, 在依据这个id进行修改 
$sql = "Insert INTO ".$this->catalog_dbname."(catalog_uid,catalog_name) 
VALUES(".$uid.",'".$name."')"; 
$result = mysql_query($sql,$this->links) 
or die("错误: 第".__LINE__."行<br>".mysql_error()); 
$catalog_id = mysql_insert_id();//获取自己的id 
$catalog_path_number = $fid_path_number.":".$catalog_id;//得到自己的数字亲缘数 
$catalog_path_char = $fid_path_char.":".$name;//得到自己的字符亲缘数 
$sql = "Update '".$this->catalog_dbname."' 
SET 
catalog_path_number = '".$catalog_path_number."', 
catalog_path_char = '".$catalog_path_char."' 
Where 
catalog_id = ".$catalog_id;   
mysql_query($sql,$this->links) 
or die("错误: 第".__LINE__."行<br>".mysql_error());   
} 
function catalog_del($id){ 
$this->connect(); 
$sql = "Delete FROM ".$this->catalog_dbname." 
Where catalog_id = ".$id; 
mysql_query($sql,$this->links) 
or die("错误: 第".__LINE__."行<br>".mysql_error()); 
} 
function catalog_set($id,$name){ 
$this->connect(); 
$sql = "Update ".$this->catalog_dbname." 
SET 
catalog_name = '".$name."' 
Where 
catalog_id = ".$id;   
mysql_query($sql,$this->links) 
or die("错误: 第".__LINE__."行<br>".mysql_error()); 
} 
} 
?>
PHP 相关文章推荐
什么是MVC,好东西啊
May 03 PHP
PHP Document 代码注释规范
Apr 13 PHP
Blitz templates 最快的PHP模板引擎
Apr 06 PHP
php环境下利用session防止页面重复刷新的具体实现
Jan 09 PHP
ThinkPHP中Common/common.php文件常用函数功能分析
May 20 PHP
功能强大的php分页函数
Jul 20 PHP
Linux平台php命令行程序处理管道数据的方法
Nov 10 PHP
PHP正则匹配日期和时间(时间戳转换)的实例代码
Dec 14 PHP
Laravel5.* 打印出执行的sql语句的方法
Jul 24 PHP
php插入mysql数据返回id的方法
May 31 PHP
PHP PDOStatement::debugDumpParams讲解
Jan 30 PHP
php实例化对象的实例方法
Nov 17 PHP
mysql时区问题
Mar 26 #PHP
How do I change MySQL timezone?
Mar 26 #PHP
有关 PHP 和 MySQL 时区的一点总结
Mar 26 #PHP
使用 MySQL Date/Time 类型
Mar 26 #PHP
MySQL修改密码方法总结
Mar 25 #PHP
用phpmyadmin更改mysql5.0登录密码
Mar 25 #PHP
常用的php ADODB使用方法集锦
Mar 25 #PHP
You might like
thinkphp分页实现效果
2016/10/13 PHP
php在windows环境下获得cpu内存实时使用率(推荐)
2018/02/08 PHP
laravel框架select2多选插件初始化默认选中项操作示例
2020/02/18 PHP
[原创]来自ImageSee官方 JavaScript图片浏览器
2008/01/16 Javascript
原生js实现模拟滚动条
2015/06/15 Javascript
jquery图片滚动放大代码分享(2)
2015/08/28 Javascript
JavaScript笔记之数据属性和存储器属性
2016/03/31 Javascript
基于javascript实现全屏漂浮广告
2016/03/31 Javascript
AngularJS 工作原理详解
2016/08/18 Javascript
详解JavaScript RegExp对象
2017/02/04 Javascript
Jquery鼠标放上去显示全名的实现方法
2017/02/06 Javascript
Angularjs为ng-click事件传递参数
2017/06/15 Javascript
vue.js中$set与数组更新方法
2018/03/08 Javascript
JavaScript+Canvas实现彩色图片转换成黑白图片的方法分析
2018/07/31 Javascript
利用原生的JavaScript实现简单拼图游戏
2018/11/18 Javascript
JavaScript canvas仿代码流瀑布
2020/02/10 Javascript
原生js实现贪吃蛇游戏
2020/10/26 Javascript
vue浏览器返回监听的具体步骤
2021/02/03 Vue.js
使用Python的Bottle框架写一个简单的服务接口的示例
2015/08/25 Python
Python判断字符串是否为字母或者数字(浮点数)的多种方法
2018/08/03 Python
Python  unittest单元测试框架的使用
2018/09/08 Python
python将.ppm格式图片转换成.jpg格式文件的方法
2018/10/27 Python
Python GUI自动化实现绕过验证码登录
2020/01/10 Python
英国领先的名牌服装折扣零售商:Brown Bag Clothing
2019/01/08 全球购物
数据库笔试题
2013/05/09 面试题
实习自我鉴定范文
2013/10/30 职场文书
高校辅导员推荐信范文
2013/12/25 职场文书
违反课堂纪律检讨书
2014/01/19 职场文书
成语的广告词
2014/03/19 职场文书
股权转让协议书范本
2014/04/12 职场文书
银行求职信怎么写
2014/05/26 职场文书
节能环保家庭事迹材料
2014/08/27 职场文书
2014年行政部工作总结
2014/11/19 职场文书
无婚姻登记记录证明
2015/06/18 职场文书
nginx作grpc的反向代理踩坑总结
2021/07/07 Servers
怎么禁用Windows 11快照布局? win11不使用快照布局的技巧
2021/11/21 数码科技