搜索
首页php教程php手册thinkphp实现左右值增、改、删操作类

新手,写了基本功能,未写排序等相关操作;求高手改进,
数据库:
thinkphp实现左右值增、改、删操作类
类库文件:
Category.class.php<?php <br /> /**<br> 应用基于thinkphp的左右值无限分类<br> **/<br> class Category<br> {<br>     //传入实化的对象【M('表名')】<br>     private $objCategory;<br>     //基础节点ID号<br>     public $intCurrentId;<br>     //设置制表符样式<br>     private $arrTabsStyle = array(<br>                             'indent' => '   ',<br>                             'process' => '├ ',<br>                             'end'=>'└ '<br>                         );<br>     //构造函数初始化<br>     public function __construct($objCategory)<br>     {<br>         $this->objCategory = $objCategory;<br>     }<br>     //验证传入ID【大于0的数字】<br>     private function checkFun($intId)<br>     {<br>         //$intId优先验证<br>         if(isset($intId))<br>         {<br>             $this->intCurrentId = $intId;<br>             return true;<br>         }<br>         //如果$this->intCurrentId 已设置,验证<br>         else<br>         {<br>             if(isset($this->intCurrentId))<br>             {<br>                 return true;<br>             }<br>             else<br>             {<br>                 return false;<br>             }<br>         }<br>     }<br>     //根据ID号获取当前节点左右值<br>     private function setCurrentData($intId)<br>     {<br>         if(false == $this->checkFun($intId))<br>         {<br>             return false;<br>         }<br>         $map['id'] = $this->intCurrentId;<br>         return $this->objCategory->field(array('lft','rgt'))->where($map)->find();<br>     }<br>     /*<br>     *作用:<br>         设置输出列表数据的制表符样式<br>     *参数:<br>         $key:arrTabsStyle的KEY<br>         $value:arrTabsStyle的值<br>     */<br>     public function setTabStyle($key, $value = '')<br>     {<br>         if(isset($this->arrTabsStyle[$key]))<br>         {<br>             $this->arrTabsStyle[$key] = $value;<br>         }<br>     }<br>     /*<br>     *作用:<br>         根据ID号获取当前节点数据<br>     *参数:<br>         $intId:可设置的,需读取节点ID号<br>     */<br>     public function getCurrentData($intId)<br>     {<br>         if(false == $this->checkFun($intId))<br>         {<br>             return false;<br>         }<br>         $map['id'] = $this->intCurrentId;<br>         return $this->objCategory->field(array('id','title'))->where($map)->find();<br>     }<br>     /*<br>     *作用:<br>         获取当前节点的父节点数据<br>     *参数:<br>         $intId:需要读取节点的ID<br>     */<br>     public function getParentCategoryData($intId)<br>     {<br>         $arrRoot = $this->setCurrentData($intId);<br>         if($arrRoot)<br>         {<br>             $map['lft'] = array('LT', $arrRoot['lft']);<br>             $map['rgt'] = array('GT', $arrRoot['rgt']);<br>             return $this->objCategory->where($map)->find();<br>         }<br>         else<br>         {<br>             return false;<br>         }<br>     }<br>     /*<br>     *作用:<br>         获取ID下节点列表<br>     *参数:<br>         $intId:需要读取节点的父ID<br>         $intLevel:目录等级默认到100级<br>     */<br>     public function getCategoryList($intId = 1, $intLevel = 100)<br>     {<br>         //获取选定节点左右值,得出取值区间<br>         $arrRoot = $this->setCurrentData($intId);<br>         if($arrRoot)<br>         {<br>             //读取数据库符合条件的数据<br>             $map['lft'] = array('BETWEEN', array($arrRoot['lft'], $arrRoot['rgt']));<br>             $arrChildList = $this->objCategory->where($map)->order('lft')->select();<br>             //return $arrChildList;<br>             //对取出数据进行格式化<br>             $arrRight = array();<br>             foreach($arrChildList as $v)<br>             {<br>                 <br>                 if(count($arrRight))<br>                 {<br>                     while ($arrRight[count($arrRight) - 1]                      {<br>                         array_pop($arrRight);<br>                     }<br>                 }<br>                 //设置读取目录等级<br>                 if($intLevel > count($arrRight))<br>                 {<br>                     $title = $v['title'];<br>                     //设置输出时的样式<br>                     if(count($arrRight))<br>                     {<br>                         $title = $this->arrTabsStyle['process'].$title;<br>                     }<br>                     $title = str_repeat($this->arrTabsStyle['indent'], count($arrRight)).$title;<br>                     $returnCategoryList[] = array('id'=>$v['id'],'title'=>$title,'lft'=>$v['lft'],'rgt'=>$v['rgt']);<br>                     $arrRight[]  = $v['rgt'];<br>                 }<br>             }<br>             return $returnCategoryList;<br>         }<br>         return false;<br>     }<br>     /*<br>     *作用:<br>         获取节点的子节点数<br>     *参数:<br>         $intId:需要读取节点的父ID<br>     */<br>     public function getCategoryCount($intId)<br>     {<br>         $arrRoot = $this->setCurrentData($intId);<br>         return ($arrRoot['rgt'] - $arrRoot['lft'] - 1) / 2;<br>     }<br>     /*<br>     *作用:<br>         添加节点<br>     *参数:<br>         $bolType:true添加到节点前面,false添加到节点尾部<br>         $intId:添加到的父节点<br>     */<br>     public function insertCategory($bolType = false, $intPid)<br>     {<br>         $data = I('param.');<br>         if(!isset($intPid))<br>         {<br>             $intPid = $data['pid'];<br>         }<br>         $arrRoot = $this->setCurrentData($intPid);<br>         if($arrRoot)<br>         {<br>             if($bolType)<br>             //true添加到节点前面<br>             {<br>                 $this->objCategory->where('rgt>'.$arrRoot['lft'])->setInc('rgt',2);<br>                 $this->objCategory->where('lft>'.$arrRoot['lft'])->setInc('lft',2);<br>                 //设置当前节点的左右值<br>                 $data['lft'] = $arrRoot['lft'] + 1;<br>                 $data['rgt'] = $arrRoot['lft'] + 2;<br>             }<br>             else<br>             //false添加到节点尾部<br>             {<br>                 $this->objCategory->where('rgt>='.$arrRoot['rgt'])->setInc('rgt',2);<br>                 $this->objCategory->where('lft>'.$arrRoot['rgt'])->setInc('lft',2);<br>                 $data['lft'] = $arrRoot['rgt'];<br>                 $data['rgt'] = $arrRoot['rgt'] + 1;<br>             }<br>             return $this->objCategory->add($data);<br>         }<br>         else<br>         {<br>             return false;<br>         }<br>     }<br>     /*<br>     *作用:<br>         删除节点<br>     *参数:<br>         $intId:被删除的节点ID<br>     */<br>     public function deleteCategory($intId)<br>     {<br>         $arrRoot = $this->setCurrentData($intId);<br>         if($arrRoot)<br>         {<br>             $ints = $arrRoot['rgt'] - $arrRoot['lft'] + 1;<br>             $map['lft'] = array('BETWEEN', array($arrRoot['lft'], $arrRoot['rgt']));<br>             $this->objCategory->where($map)->delete();<br>             $this->objCategory->where('lft>'.$arrRoot['rgt'])->setDec('lft',$ints);<br>             $this->objCategory->where('rgt>'.$arrRoot['rgt'])->setDec('rgt',$ints);<br>             return true;<br>         }<br>         else<br>         {<br>             return false;<br>         }<br>     }<br>     /*<br>     *作用:<br>         更新节点<br>     *参数:<br>         $intId:被删除的节点ID<br>     */<br>     public function updateCategory()<br>     {<br>         //读取POST数据存入数组<br>         $data = I('param.');<br>         //父ID等于子ID,直接跳出<br>         if($data['pid'] == $data['id']){return false;}<br>         //post.pid和当前父post.old相等说明未改变目录,不更新左右值<br>         if($data['pid'] !== $data['oldpid'])<br>         {<br> /**********************************【读取所需的相关值】********************************/<br>             //获取新的父节点的数据<br>             $arrParent = $this->setCurrentData($data['pid']);<br>             //取当前节点的数据<br>             $arrCurrent = $this->setCurrentData($data['id']);<br> /* 任务:删除节点 */<br> /**********************************【A-1:隔离数据】************************************/<br>             //将需要调整位置的左右值+100000<br>             $map['lft'] = array(<br>                         array('EGT', $arrCurrent['lft']),<br>                         array('ELT', $arrCurrent['rgt'])<br>                     );<br>             $this->objCategory->where($map)->setInc('lft',100000);<br>             //因为左值已更新,所以条件变化+100000<br>             $map['lft'] = array(<br>                         array('EGT', $arrCurrent['lft'] + 100000),<br>                         array('ELT', $arrCurrent['rgt'] + 100000)<br>                     );<br>             $this->objCategory->where($map)->setInc('rgt',100000);<br>             unset($map);<br> /**********************************【A-2:更新正常节点值】******************************/<br>             //获取隔离节点后续更新的步长值<br>             $intStep = $arrCurrent['rgt'] - $arrCurrent['lft'] + 1;<br>             //更新节点左右值<br>             $map['lft'] = array(<br>                         array('GT', $arrCurrent['rgt']),<br>                         array('LT', 100000)<br>                     );<br>             $this->objCategory->where($map)->setDec('lft',$intStep);<br>             unset($map);<br>             $map['rgt'] = array(<br>                         array('GT', $arrCurrent['rgt']),<br>                         array('LT', 100000)<br>                     );<br>             $this->objCategory->where($map)->setDec('rgt',$intStep);<br>             unset($map);<br> /* 完成:删除节点 */<br> /* 任务:更新节点 */<br> /**********************************【B-1:新父节目点提供下级节点的空间】****************/<br>             $map['lft'] = array(<br>                         array('GT', $arrParent['lft']),<br>                         array('LT', 100000)<br>                     );<br>             $this->objCategory->where($map)->setInc('lft',$intStep);<br>             unset($map);<br>             $map['rgt'] = array(<br>                         array('GT', $arrParent['lft']),<br>                         array('LT', 100000)<br>                     );<br>             $this->objCategory->where($map)->setInc('rgt',$intStep);<br>             unset($map);<br> /**********************************【B-2:将节点放入指定下级的空间】********************/<br>             //获取隔离节点后续更新的步长值<br>             $intStep = 100000 + ($arrCurrent['lft'] - ($arrParent['lft'] + 1));<br>             //更新左右值大于父节点左值的节点的左右值<br>             $map['lft'] = array(<br>                         array('EGT', $arrCurrent['lft'] + 100000),<br>                         array('ELT', $arrCurrent['rgt'] + 100000)<br>                     );<br>             $this->objCategory->where($map)->setDec('lft',$intStep);<br>             unset($map);<br>             $map['rgt'] = array(<br>                         array('EGT', $arrCurrent['lft'] + 100000),<br>                         array('ELT', $arrCurrent['rgt'] + 100000)<br>                     );<br>             $this->objCategory->where($map)->setDec('rgt',$intStep);<br>         }<br>         return $this->objCategory->where('id='.$data['id'])->setField('title', $data['title']);<br>     }<br> }<br> ?>使用:<?php <br /> class CategoryAction extends CommonAction {<br>     private $objCG;<br>     public function _initialize(){<br>         //导入分类库<br>         import('@.ORG.Util.Category');<br>         $this->objCG = new Category(M('CommonCategory'));<br>     }<br>     //目录列表<br>     public function index($id = 1){<br>         $this->cateorylist = $this->objCG->getCategoryList($id);<br>         $this->display();<br>     }<br>     //添加目录<br>     public function add($id=1){<br>         $this->cateorylist = $this->objCG->getCategoryList($id);<br>         $this->display();<br>     }<br>     //编辑目录<br>     public function edit($id){<br>         if (!empty($id)){<br>             //输出所有的节点<br>             $this->cateorylist = $this->objCG->getCategoryList(1);<br>             //读取当前节点数据<br>             $vo = $this->objCG->getCurrentData($id);<br>             if ($vo){<br>                 //读取当前节点的父节点数据<br>                 $arrParent = $this->objCG->getParentCategoryData($id);<br>                 $vo['pid'] = $arrParent['id'];<br>                 $this->assign('vo',$vo);<br>                 $this->display();<br>             }else{<br>                 $this->error('数据不存在!');<br>             }<br>         }else{<br>             $this->error('数据不存在!');<br>         }<br>     }<br>     //添加目录:操作<br>     public function insert(){<br>         $list = $this->objCG->insertCategory();<br>         if ($list !== false)<br>         {<br>             $this->success('数据保存成功!');<br>         }<br>         else<br>         {<br>             $this->error('数据写入错误!');<br>         }<br>     }<br>     public function delete($id){<br>         if (!empty($id))<br>         {<br>             $result = $this->objCG->deleteCategory($id);<br>             if ($result)<br>             {<br>                 $this->success('删除成功!');<br>             }<br>             else<br>             {<br>                 $this->error('删除出错!');<br>             }<br>         }<br>         else<br>         {<br>             $this->error('ID错误!');<br>         }<br>     }<br>     public function update(){<br>         $list = $this->objCG->updateCategory();<br>         if ($list !== false)<br>         {<br>             $this->success('更新成功!');<br>         }<br>         else<br>         {<br>             $this->error("操作失败!");<br>         }<br>     }<br> }

AD:真正免费,域名+虚机+企业邮箱=0元

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境