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元

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

了解Python程式設計的入門程式碼範例Python是一種簡單易學,功能強大的程式語言。對於初學者來說,了解Python程式設計的入門級程式碼範例是非常重要的。本文將為您提供一些具體的程式碼範例,幫助您快速入門。列印HelloWorldprint("HelloWorld")這是Python中最簡單的程式碼範例。 print()函數用於將指定的內容輸出

《Go語言程式設計實例:Web開發中的程式碼範例》隨著網路的快速發展,Web開發已成為各行業中不可或缺的一部分。作為一門功能強大且效能優越的程式語言,Go語言在Web開發中越來越受到開發者們的青睞。本文將透過具體的程式碼範例,介紹如何利用Go語言進行Web開發,讓讀者更能理解並運用Go語言來建立自己的Web應用。 1.簡單的HTTP伺服器首先,讓我們從一個

PHP變數儲存程式運行期間的值,對於建立動態且互動的WEB應用程式至關重要。本文將深入探討php變量,並透過10個真實的範例展示它們的實際應用。 1.儲存使用者輸入$username=$_POST["username"];$passWord=$_POST["password"];此範例從表單提交中提取使用者名稱和密碼,並將其儲存在變數中以供進一步處理。 2.設定配置值$database_host="localhost";$database_username="username";$database_pa

如何使用PHP編寫庫存管理系統中的庫存分倉管理功能碼庫存管理是許多企業中不可或缺的一部分。對於擁有多個倉庫的企業來說,庫存分倉管理功能尤其重要。透過合理管理和追蹤庫存,企業可以實現不同倉庫之間的庫存調撥,優化營運成本,改善協同效率。本文將介紹如何使用PHP編寫庫存分倉管理功能的程式碼,並為您提供相關的程式碼範例。一、建立資料庫在開始編寫庫存分倉管理功能的程式碼之

Java冒泡排序最簡單的程式碼範例冒泡排序是一種常見的排序演算法,它的基本想法是透過相鄰元素的比較和交換來將待排序序列逐步調整為有序序列。以下是一個簡單的Java程式碼範例,示範如何實作冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

華為雲端邊緣運算對接指南:Java程式碼範例快速實現介面隨著物聯網技術的快速發展和邊緣運算的興起,越來越多的企業開始關注邊緣運算的應用。華為雲端提供了邊緣運算服務,為企業提供了高可靠的運算資源和便利的開發環境,使得邊緣運算應用更容易實現。本文將介紹如何透過Java程式碼快速實現華為雲端邊緣運算的介面。首先,我們需要準備好開發環境。確保你已經安裝了Java開發工具包(

標題:從入門到精通:Go語言中常用資料結構的程式碼實作資料結構在程式設計中起著至關重要的作用,它是程式設計的基礎。在Go語言中,有許多常用的資料結構,掌握這些資料結構的實作方式對於成為優秀的程式設計師至關重要。本文將介紹Go語言中常用的資料結構,並給出對應的程式碼範例,幫助讀者從入門到精通這些資料結構。 1.數組(Array)數組是一種基本的資料結構,是一組相同類型

Java選擇排序法程式碼編寫指南及範例選擇排序是一種簡單直觀的排序演算法,其想法是每次從未排序的元素中選擇最小(或最大)的元素進行交換,直到所有元素排序完成。本文將提供選擇排序的程式碼編寫指南,並附上具體的Java範例程式碼。演算法原理選擇排序的基本原理是將待排序數組分為已排序和未排序兩部分,每次從未排序部分選擇最小(或最大)的元素,將其放到已排序部分的末尾。重複上述
