PHP进阶教程:实现网站的无限分类的方法

    作者:课课家教育更新于: 2015-11-26 16:41:50

    大神带你学编程,欢迎选课

    今天由小编为大家讲解有关语言编程的文章,在课课家共同了解语言编程其中不被重视的技巧相信对大家一定有很大的帮助

    1、分析
    php教程我们在用 php 制作网站时,分类是很重要的,在分类下面又再分类这第二个分类称为次分类,而现在大多数网站分类只分到第三类:
    第一分类(父分类)-->第二分类(子分类)-->第三分类(孙分类)
    这种亲缘分类越多,程序和的控制就越加的复杂困难。在同一级的分类处理和控制是非常的简单的,因为只需要一个数据库来记载这一级的分类就行了,如:系统,新闻等分类,在这一级上处理是很简单的,但对一个网站来说一级分类是不够的,还需要再分类,如:
    系统-->linux,windows
    新闻-->linux 新闻,windows 新闻
    这样分类就清晰些了,至少让人明白了,系统包括 linux 和 windows,而新闻包括 linux 新闻和 windows 新闻,为了让信息资料更加清晰,于是再继续分类:
    linux-->系统工具,内核,,
    分类到了第**,信息资料的处理就更清晰了,也就是说为了很清晰地处理资料,分类越详细就越方便,这样即方便处理信息又方便网友目的明确地查找到需要的资料,但随着不断的细化分类,在程序和数据库的控制上就会越来越困难。
    困难一:如何在数据库里处理这些互有关联的亲缘分类?
    困难二:如何用 php 完成这种一目了然的关系?
    这种分级多而细的分类是每个 php 程序员都必须解决的问题,因为制作一个好而出色的网站分类问题是不可避免的,而解决这个问题又是相当复杂的,其中最大的问题就是数据库的分类处理,因为如果数据库处理不当将会带来巨大的工作量甚至是不得不重新规划数据库...
    这并不是夸张,因为很多人在数据库处理上就会采用一级分类建立一个数据库的做法,我当时也是采取这种方法处理分类的,因大多网站都是分到第**,所以数据库里只需三个分类数据库来进行处理.但是需要继续向下分类时,这种做法的弊端就显露出来了,因为越往下分,工作量,程序量将会巨增..
    我要介绍的这种方法就是如何用一个分类数据库建立无限向下分级的分类方法,用过 windows 的读者都知道 windows 文件夹就可以建立无限分级的目录,可在目录下面继续建立目录,这样没完没了的分下去, 的目录创建也有这种功能,我介绍的这个方法跟这种形式相同。
    2、数据库的规划
    前面谈到分类的复杂性,因此如何规划数据库便成为了实现无限分类非常重要的一步。
    我曾介绍过论坛的数据库规划,不错论坛能够实现无限的跟接,无限分类便是这种形式的扩展,分类同样是这种子父的关联关系,所以分类的数据库就是如何确立明确这种子父关系,这里面有几个难点。
    1)如何处理各分类的信息存储;
    2)如何处理分类的亲缘关系;
    3)如何处理对信息的查询;
    亲缘关系的数据库处理与论坛的数据库处理类似,这里建个 type 的数据库用来处理分类:
    建立字段:
    id(int):用来记录各分类的自然序号
    uid(int):用来记录该分类的父分类的 id 号
    type(char):类别的名称
    roue_id(varchar):亲缘树,以 :0:2:10:20: 的 id 连接表明亲源关系
    roue_char(varchar):亲缘树,类似 :系统:linux:开发工具:gcc: (这个字段有没有都没关系,为了更方便地了解各亲缘关系当然字符表述比数字表述更直接,不过最好加上这个字段)
    这样一个无限分类的类别表就建立了起来,接下来就需要建立存储信息的数据库,处理查询一个表最方便所以这里建立一个表存储信
    type_message:
    id(int):信息的序号;
    typeid(int):所属类别的 id 号;
    title(varchar):信息标题;
    message(text):信息内容;
    time:信息建立的时间;
    这两个数据表就能够完成无限分类的这个任务了(两个表的辅助字段就没加了,读者可自行加入)。
    剩下的任务就全部交由 php 来处理完成。
    3、程序控制
    实现无限分类这个功能中就属这一步最为复杂辛苦,首先看看程序需要完成的步骤:
    1)创建分类上传;
    2)创建信息上传;
    3)明确显示各分类及其之间的关系;
    4)处理查询功能;
    5)如何处理编辑和删除的功能;
    而这五步中最为困难的就是第五个步骤,因为对分类的编辑和删除涉及到一至性的问题
    下面我就逐一描述 php 的程序控制:
    1)创建分类上传
    在介绍这个功能前,先介绍一下 explode( ) 这个函数,这是个字串处理函数,用来分解字串的,具体的用法,例:
    分解"0:1:2:3:4"里的数字

    以下为引用的内容:
    $val='0:1:2:3:4';
    $rid=explode(":",$val);


    经过 explode( ) 函数处理,$val 内的所有数字都分解到 $rid 数组中了,要引用时只需打印:echo '$rid[0],$rid[1],$rid[2]..."; 就行了.explode( ) 函数在整个分类处理中起着非常重要的作用,好现在开始介绍无现分类的程序控制。
    可以假设个总分类 0 ,所有的分类都是它的子孙分类,现在来建立第一个分类'系统',来看看它在数据库的存储形式:
    id | uid | type | rout_id | rout_char 1 | 0 | 系统 | 0:1 | 系统
    接着又在下面分'Linux':
    id | uid | type | rout_id | rout_char 2 | 1 | Linux| 0:1:2 | 系统:Linux
    以上就是数据库存储的形式,现在就来完成 php 的代码,这与论坛的代码很相似,我们所要做的就是将分类的 id 放入 uid,而父分类的 uid 就放 0,下面来看看代码:

    well"我从事编程语言统计很多年了,有大量的数据来源包括代码存储库、Q&A讨论、招聘广告、社交媒体情况、教程页面访问、学习视频视图、开发者调查等等。数据发表在不同的时间,都可以被认为是精确的,
    也可以被认为是有缺陷的,但是它们可以用于发现行业趋势。最后,不要期望一夜之间就变成一个编码忍者。有些人有一种天然的能力,但也是花了很多很多时间来磨练他们的技能,不断的学习新的技术和技巧。"
    在过去三年中 XML 经历了许多反复,所以目前存在不同版本的 Microsoft XML 分析器也不奇怪。Internet Explorer 4.0 包含早期版本的 XML 分析器,它比 XSL、XML 数据或者大多数其他的 XML 技术(并且有完全不同的 DOM 模型)要早。该早期版本的分析器包含在 MSXML.dll 库中。从 MSDN XML 开发人员中心(英文)可将分析器升级到较新的一种。
      我们极力建议您升级到新的分析器,因为它要强大得多。Internet Explorer 5.0 包括 MSXML 2.0 分析器,它包含 XSL 和 XML 架构的基本版本。MSXML2 是 SQL Server 2000 附带的分析器版本。MSXML2 包含了许多性能增强的功能,并且在总体上提高了性能和可伸缩性。MSXML3 是当前作为“技术预览”附带的版本。MSXML3 包括 XSLT 和 XPath 支持以及 SAX 接口。

    在网站维护中,站长朋友常常要对网站数据进行备份,以免出现意外情况而造成数据的损失。一般的下载备份方法不仅麻烦而且速度缓慢。这时我们就可以使用程序提供的文件压缩功能来快速进行网站数据的备份。
    首先将需要备份的网站文件前的复选框选中,然后点击“添加到压缩文件”超连接,接着在弹出的对话框中输入文件名称,注意一定要输入以zip为后缀的压缩文件格式。确定后稍等片刻,一个文件压缩包就制作完成了。只需要将其下载,放置在安全的地方保存就可以了。
    php实例教程在管理器主页面的功能菜单中选择“上传文件”按钮,将在网页最下方打开文件上传模块(如图2),点击“浏览”按钮选择本地文件,然后再点击上传即可。程序中的文件容量栏目会自动显示该文件占用网站空间的大小,文件大小会以KB或Byte两种单位显示。我们可以根据此功能方便的对网站文件进行整理归类操作;点击下载超连接可以将网站文件下载到本地硬盘,操作方式与普通下载方式无异,还可以使用迅雷等下载工具进行文件的高速下载;软件还提供了功能强大的编辑器(如图3),点击编辑连接后会显示文件的源代码,它还提供了本地预览与在线预览的功能,使网站文件的调试工作变得非常简单高效;

    以下为引用的内容:

    .....
    .....
    //设置默认页
    if (empty($func)) $func=='showtype';
    //设置父分类的 uid
    if (empty($uid)) $uid=0;
    //数据库存储************************************************
    if ($func=='save'):
    $fields = "";
    $values = "";
    if ($id!="") {
    $fields .= ",id";
    $values.=",$id";
    }
    if ($uid!="") {
    $fields .= ",uid";
    $values.=",$uid";
    }
    if ($type!="") {
    $fields .= ",type";
    $values.=",'$type'";
    }
    if ($route_id=="") {
    //取得父分类的 route_id
    if ($uid!=0) {
    $result = mysqlquery("select * from type where id=$uid");
    $route_id=mysql_result($result,0,"route_id");
    } else {
    $routr_id='0';
    }
    $fields .= ",route_id";
    //形成自己的 route_id
    $route_id="$route_id:$id";
    $values.=",'$route_id'";
    }
    //形成自己的 route_char
    if ($route_char!="") {
    $fields .= ",route_char";
    $route_char="$route_char:$type";
    $values.=",'$route_char'";
    } else {
    $fields .= ",route_char";
    $route_char=$type;
    $values.=",'$route_char'";
    }
    $fields = substr($fields,1,strlen($fields)-1);
    $values = substr($values,1,strlen($values)-1);
    $result = mysqlquery("insert into type ($fields) values ($values)");
    ...
    endif; /* end save */
    //分类上传************************************************
    if ($func=='createtype'):
    //取得自己的 id
    $result = mysqlquery("select * from type order by
    id desc");
    $num=mysql_numrows($result);
    if (!empty($num)) {
    $cat = mysql_result($result,0,"id");
    } else {
    $cat=0;
    }
    //判断分类的状态
    if ($uid != 0) {
    $result=mysql_query("select * from type where id=$uid");
    $type=mysql_result($result,0,"type");
    $route_char=mysql_result($result,0,"route_char");
    } else {
    $type='父分类';
    }
    echo "
    PHP_SELF?func=save" METHOD=POST>";
    echo ""; echo ""; echo ""; echo ""; echo "
    所属类别:$type
    创建分类:
    ";
    $cat=$cat+1;
    echo "";
    echo "";
    echo "";
    echo "
    ";
    echo "
    ";
    endif; /* end createtype */
    //显示分类************************************************
    if ($func=='showtype'):
    echo ""; //判断分类的状态 if ($uid!=0) { $result=mysql_query("select * from type where id=$uid"); $type=mysql_result($result,0,"type"); } else { $type='父分类'; } echo ""; echo ""; $result=mysql_query("select * from type where uid=$uid"); $num=mysql_numrows($result); if (!empty($num)) { for ($i=0;$i<$num;$i++) { $id=mysql_result($result,$i,"id"); $type=mysql_result($result,$i,"type"); echo ""; } } echo "
    $type
    ";
    echo "";
    echo "
    ";
    endif; /* end showtype */
    .....
    .....
    ?>


    以上的程序便完成了无限分类的基本创建,存储和显示,接着就是完善分类创建功能的各个部分了。
    4、路径跟踪
    前面已经介绍过了分类的创建实现方法,php视频教程在分类表里记载了 rout_id 和 rout_char 这两个存储分类路径的信息,在不做任何处理的情况下,程序只能够顺序下到最底层的分类而无法倒退(当然可利用浏览器的 back 键倒退,但这对程序来说是不完整的),因此必须将 rout_id 和 rout_char 的信息分解出来完成实在的路径指示。
    具体的做法,假如数据库记载了这么一条分类信息:

    以下为引用的内容:
    id:4
    uid:2
    type:开发工具
    rout_id:0:1:2:4
    rout_char:系统:linux:开发工具


    当程序走到分类'开发工具'上时,除了要求显示路径信息外还要求能够去到路径上的任一分类中,该怎么做能?这里就需要用到 explode() 函数了.因为 rout_id 和 rout_char 是对应关系的,所以可将它们分解:

    以下为引用的内容:
    $path=explode(":",$rout_id);
    $path_gb=explode(":",$rout_char);


    这时所有分类信息都被分解了,现在要做的就是以链接的方式还原路径信息:

    以下为引用的内容:
    for ($i=0;;$i++) {
    $a=$i+1;
    echo "href=$php_self?func=showtype&uid=",$path[$a],">",$path_gb[$i],":";
    if (empty($path_gb[$i])) {
    break;
    }
    }


    上面这段代码就实现了加链接还原路径的功能,因为实现的是无限分类,因此是没有上限的,所以在 for($i=0;;$i++) 里没有范围限制,而设置循环退出的条件是 $path_gb[$i] 中的值为空,将这段代码插入类别显示版面的程序块内就行了:

    以下为引用的内容:

    .....
    .....
    //显示分类************************************************
    if ($func=='showtype'):
    echo ""; //判断分类的状态 if ($uid!=0) { $result=mysql_query("select * from type where id=$uid"); $type=mysql_result($result,0,"type"); //******** 新加入的代码 *************** $rout_id=mysql_result($result,0,"rout_id"); $rout_char=mysql_result($result,0,"rout_char"); $path=explode(":",$rout_id); $path_gb=explode(":",$rout_char); echo ""; //******** end *********************** } else { $type='父分类'; } echo ""; echo ""; $result=mysql_query("select * from type where uid=$uid"); $num=mysql_numrows($result); if (!empty($num)) { for ($i=0;$i<$num;$i++) { $id=mysql_result($result,$i,"id"); $type=mysql_result($result,$i,"type"); echo ""; } } echo "
    ";
    for ($i=0;;$i++) {
    $a=$i+1;
    echo "href=$php_self?func=showtype&uid=",$path[$a],">",$path_gb[$i],":";
    if (empty($path_gb[$i])) {
    break;
    }
    }
    echo "
    $type
    ";
    echo " ;
    echo "
    ";
    endif; /* end showtype */
    .....
    .....
    ?>


    完成这个功能块后,就可继续分类信息的显示实现了...

    看完小编的文章是不是很精彩,是不是想要成为编程语言的高手,更多关于在线教育的文章尽在课课家,希望你们多多关注。

课课家教育

未登录

1