使用ThinkPHP的自动完成实现无限级分类实例详解
更新时间:2016年09月02日 14:41:25 作者:TigerYangWTH
这篇文章主要介绍了使用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的自动完成实现无限级分类实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
php安装xdebug/php安装pear/phpunit详解步骤(图)
PHP环境中安装pear、phpunit以及xdebug全攻略,大家参考使用吧2013-12-12WordPress特定文章对搜索引擎隐藏或只允许搜索引擎查看
这篇文章主要介绍了WordPress特定文章对搜索引擎隐藏或只允许搜索引擎查看的方法,可以根据SEO的需要来进行调整,需要的朋友可以参考下2015-12-12php把数据表导出为Excel表的最简单、最快的方法(不用插件)
很多时候,数据库中的数据需要导出成excel,以下是最简便的方法,不用导出excel的类,即使功能简单,但是对于没有复杂需求的项目“见效快”2014-05-05
最新评论