阅读模式:

php无限分类,递归分类

查看:4313  回复:0  类型:  来源:php自学网  标签 php

很简单的php无限分类递归的实现方法,php 最大分类不能超过200级。

添加分类页面:


add.html添加分类页面:

<html>
<head>
<title>添加分类</title>
<meta charset="utf-8">
</head>
<body>
<?php
    require "function.php";
    $fid=$_GET['cate'];
    $title=$_GET['title'];
    if(isset($fid) and isset($title)){
        add($title,$fid);//如果接收到分类id和分类名就添加到数据库
    }
    
?>
<table>
    <form action="add.php" method="get">
    <tr>
        <td>分类选择:</td>
        <td>
            <select name="cate">
            <option value="0">默认</option>
                <?php
                function menu($fid=0,$levels){//循环分类
                    for($n=0;$n<$levels;$n++){
                        $nv.='&nbsp;&nbsp;'; //拼接空格  
                    }
                    $nv.='|--'; //分类图标
                    $levels++;  //添加分类级别
                    $sql="select * from category where fid={$fid} order by id asc";
                    $res =mysql_query($sql);
                    if($res && mysql_affected_rows()){  //查找子分类,如果有子分类就继续遍历下级子分类
                        while($v=mysql_fetch_array($res)){
                            echo "<option value="{$v['id']}">{$nv}{$v['title']}</option>";
                            menu($v['id'],$levels); //递归下级分类,如果有子类
                        }
                    }
                }
                    menu(0,1);//调用
                ?>
                
            </select>
        </td>    
    </tr>
    <tr>
        <td>类别名称:</td>
        <td>
            <input type="text" name="title" />
        </td>  
    </tr>
    <tr>
        <td></td>
        <td><input type="submit" value="提交" /></td>
    </tr>
    </form>
    
    <tr>
        <td>所有分类:</td>
        <td>
            <?php
                lists(0,0);
            ?>
            
        </td>    
    </tr>
</table>
</body>
</html>

function.php页面:

<?php
    header("content-type:text/html;charset=utf-8");
    $conn = mysql_connect('localhost','root','');
    mysql_select_db('test');
    mysql_query('set names utf8'); //连接数据库
    
    function add($title,$fid){
        $sql="insert into category (title,fid) values ('$title','$fid')";
        if(mysql_query($sql)){
            echo '<script>alert('添加分类成功');window.location.href='add.php'</script>';  //添加分类
        }
    }
    function lists($fid,$level){  //遍历所有分类
        for($n=0;$n<$level;$n++){
            $nv.='&nbsp;&nbsp;';
        }
        $nv.='|--';
        $level++;
        $sql="select * from category where fid={$fid} order by id asc";
        $r=mysql_query($sql);
        
        if($r && mysql_affected_rows()){ //如果有下级分类就遍历下去
            while($val=mysql_fetch_array($r)){
                echo "<p>{$val['fid']}{$nv}{$val['title']}{$i}</p>";
                lists($val['id'],$level);
            }
        }
    }
?>

数据库设置了三个字段  id  title  fid

分享到:
0 0

*有问题之处烦请在评论中指出非常感谢!
不是我想要的内容,继续搜索:

扫描二维码手机查看

发布评论:


登录:
  表情:
评论话题
推荐阅读:
session与cookie的区别   阅读:3923网站局部小图片优化-base64编码图片   阅读:11108比phpexcel还要简单的excel CSV 一键导入数据到数据库   阅读:5116php删除一个文件夹内的所有文件夹和文件   阅读:4477phpexcel 超简单从excel表格一键导入数据到数据库教程   阅读:11666nginx安装mysql和json模块   阅读:4274用php从1乘到100的值   阅读:5896HTTP 1.1 协议详解   阅读:9896session与cookie的区别   阅读:3923“米粉节”背后的故事——小米网抢购系统开发实践   阅读:3821面试都会问你为什么你从上一家公司离职的真实意思   阅读:10513shell脚本批量删除几天前的文件   阅读:9026mysql 为什么添加索引可以提高访问速度   阅读:5635phpexcel 超简单从数据库一键导出数据到excel教程   阅读:6824centos 7 安装 nginx-1.11.10   阅读:7951面试的时候回去等通知,等电话的真实意思   阅读:22869十张GIF让你弄懂递归等概念   阅读:5683csv文件一键导入数据到mysql数据库   阅读:6256session与cookie的区别   阅读:3923面试都会问你为什么你从上一家公司离职的真实意思   阅读:10513mysql数据一键导出到csv文件   阅读:5257javascript获取两个日期间的所有日期   阅读:6093栈和堆的区别   阅读:4664Mysql在大型网站的应用架构演变   阅读:4287php中地址引用&的真正理解-变量引用、函数引用、对象引用   阅读:5243web性能测试工具ab的测试方法   阅读:4319霍金24岁博士毕业论文在线预览   阅读:5251linux命令中执行php脚本   阅读:7354移动端自适应rem原理   阅读:9264最简单的Banner轮播左右切换效果代码及实现思路(附带源码)   阅读:30620比phpexcel还要简单的excel CSV 一键导入数据到数据库   阅读:5116centos 7.2 添加php7 的 php-fpm 开机启动   阅读:23204用php从1乘到100的值   阅读:5896一步步带你,如何网站架构   阅读:3796移动端js触摸touch详解(附带案例源码)   阅读:15814移动端js触摸touch详解(附带案例源码)   阅读:15814mysql 为什么添加索引可以提高访问速度   阅读:5635shell发送邮件脚本   阅读:6853shell脚本统计当前服务器并发连接数   阅读:6709linux教程,鸟哥私房菜(pdf全集)   阅读:9093php连接redis   阅读:5330最简单的Banner轮播左右切换效果代码及实现思路(附带源码)   阅读:30620web项目高并发量网站解决方案   阅读:4280php冒泡排序法   阅读:13429mysql中文分词全文搜索索引讯搜的安装   阅读:6315程序员找工作三要素(必看)   阅读:5312centos7开启交换内存   阅读:10210mysql中文分词全文搜索索引讯搜的安装   阅读:6315十张GIF让你弄懂递归等概念   阅读:5683phpexcel 超简单从数据库一键导出数据到excel教程   阅读:6824