使用ThinkPHP的自动完成实现无限级分类实例详解

一、实现效果

 

二、主要代码

  1、模板

  2、控制器

    ·index模块

    ·add模块

 

  3、模型

三、代码

  以便于各位看官复制测试

  1、模板

<form action="__URL__/add" method="post"> 栏目<select name="fid" size=20> <option value="0">栏目</option> <volist name='list' id='vo'> <option value="{$vo['id']}"> {$vo['blank']}{$vo['name']}</option> </volist> </select><br/> 添加栏目:<input type="text" name='name'/><br/> <input type="submit" value="添加"/>  </form>

  2、控制器

<?php class IndexAction extends Action { /** +---------------------------------------------------------- * 默认操作 +---------------------------------------------------------- */ public function index(){ $Column=new ColumnModel(); $list=$Column->field("id,name,fid,sort,concat(sort,'-',id) nsort")->order('nsort asc')->select(); foreach($list as $key=>$val){ $layer=count(explode('-',$list[$key]['nsort'])); $list[$key]['blank']=''; for($i=0;$i<$layer;$i++){ if($i==$layer-1){ $list[$key]['blank'].='---|'; }else{ $list[$key]['blank'].='---'; } } } $this->assign('list',$list); $this->display(); } public function add(){ $Column=new ColumnModel; $Column->create(); if($Column->add()){ $this->success('添加成功'); }else{ $this->error($Column->getError()); } } } ?>

  3、模型

<?php class ColumnModel extends Model{ protected $_auto=array( array('name','trim',0,'function'),//过滤用户不小心输入的空白字符 array('sort','createsort',0,'callback'), ); /* *自动完成sort字段 *根据POST过来的fid来查询上级sort,以确定本级sort */ protected function createsort(){ $fid=$_POST['fid']?(int)$_POST['fid']:0;//如果用户没有选择父栏目,则默认父栏目id为0 if($fid!='0'){ $list=$this->where("id=$fid")->find(); $data=$list['sort'].'-'.$fid; }else{ $data='0'; } return $data; } } ?>

以上所述是小编给大家介绍的ThinkPHP的自动完成实现无限级分类实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

时间: 2024-07-30 13:22:39

使用ThinkPHP的自动完成实现无限级分类实例详解的相关文章

使用ThinkPHP的自动完成实现无限级分类实例详解_php实例

一.实现效果 二.主要代码 1.模板 2.控制器 ·index模块 ·add模块 3.模型 三.代码 以便于各位看官复制测试 1.模板 <form action="__URL__/add" method="post"> 栏目<select name="fid" size=20> <option value="0">栏目</option> <volist name='list

php+mysql实现无限分类实例详解

 这篇文章主要介绍了php+mysql实现无限分类的方法,实例分析了mysql数据库设计.数据库操作及无限极分类的具体实现步骤,非常具有实用价值,需要的朋友可以参考下     本文实例讲述了php+mysql实现无限分类的方法.分享给大家供大家参考.具体分析如下: 1.数据库通过设置父类ID来进行唯一索引,然后使用函数的递归调用实现无限分类: 2.数据库设计通过特定格式进行排列,然后使用mysql查询关键函数:concat,程序实现比较简单,首先我们假设有这样的一个三级分类,新闻→PHP新闻→P

ThinkPHP模板循环输出Volist标签用法实例详解_php实例

本文实例讲述了ThinkPHP模板循环输出Volist标签用法.分享给大家供大家参考,具体如下: volist 标签用于在模板中循环输出数据集或者多维数组. volist 标签 在模块操作中,select() 方法返回的是一个二维数组,可以用 volist 直接输出: <volist name="list" id="vo"> 用 户 名:{$vo['username']}<br /> 电子邮件:{$vo['email']}<br /&g

ThinkPHP自动填充实现无限级分类的方法_php实例

本文实例展示了ThinkPHP自动填充实现无限级分类的方法,是ThinkPHP常用功能之一,非常具有实用价值.现将完整实例分享给大家,供大家参考.具体实现步骤如下: 表aoli_cate如下图所示: 一.action部分: aoli/Home/Lib/Action/CataAction.class.php文件如下: <?php class CateAction extends Action{ function index(){ $cate=M('cate'); $list=$cate->fie

ThinkPHP之import方法实例详解_php实例

import方法是ThinkPHP框架用于类库导入的封装实现,尤其对于项目类库.扩展类库和第三方类库的导入支持,import方法早期的版本可以和java的import方法一样导入目录和通配符导入,后来考虑到性能问题,在后续的版本更新中不断改进和简化了,所以现在的用法比较简单明了.调用格式: import('类库名', '起始路径', '类库后缀') imprt方法有一个别名vendor方法,专门用于导入第三方类库,区别在于起始路径和类库后缀默认值不同. 我们来分析下具体的用法: 1.导入系统基类

thinkphp命名空间用法实例详解_php实例

本文实例讲述了thinkphp命名空间用法.分享给大家供大家参考,具体如下: 新版本(3.2)中采用命名空间的方式定义和加载类库文件,解决多个模块之间的冲突问题,并实现了更加高效的自动加载机制. 需要给类库定义所在的命名空间,命名空间的路径和类库文件的目录一致,就可以实现类的自动加载,例如Org\Util\File类的定义为 namespace Org\Util; class File { } 其所在的路径是ThinkPHP/Library/Org/Util/File.class.php,我们实

thinkPHP数据库增删改查操作方法实例详解_php实例

本文实例讲述了thinkPHP数据库增删改查操作方法.分享给大家供大家参考,具体如下: thinkphp对数据库增删改查进行了封装操作,使得使用更加方便,但是不一定灵活. 可以用封装的用,需要写sql,可以执行sql. 1.原始的 $Model = new Model(); // 实例化一个model对象 没有对应任何数据表 $insert_sql = "INSERT INTO sh_wxuser_collection (user_id,store_id,good_id,addtime) VAL

编程c语言-C语言cmd自动写入,求大神详解

问题描述 C语言cmd自动写入,求大神详解 在程序中用system("cmd.exe");建立新的cmd窗口写入字符串并执行.怎样实现? 解决方案 system("cmd.exe /k 你的命令"); 写入字符串 system("cmd.exe /k echo 你的字符串"); 解决方案二: cmd /c 命令,或者cmd /k 命令.

ThinkPHP之N方法实例详解_php实例

ThinkPHP的N方法属于计数器方法,被用于核心的查询.缓存统计的计数和统计.但是其实可以用于应用的其他计数用途,用法比较简单,调用格式: N('计数位置'[,'步进值']) 例如,我们要统计页面中的查询次数,可以用 N('read',1); 表示每次执行到该位置都会引起计数器加1,到页面结束之前,我们就可以用 $count = N('read'); 来统计当前页面执行的查询数目. 如果你希望计数器每次增加5,那么可以改变步进值,例如: N('score',5); 需要注意的是,N方法页面执行