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 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









入門コード例で Python プログラミングについて学ぶ Python は、習得が簡単でありながら強力なプログラミング言語です。初心者にとって、Python プログラミングの入門コード例を理解することは非常に重要です。この記事では、すぐに始めるのに役立つ具体的なコード例をいくつか紹介します。 Print HelloWorldprint("HelloWorld") これは、Python の最も単純なコード例です。 print()関数は、指定された内容を出力するために使用されます。

PHP 変数はプログラムの実行中に値を保存し、動的でインタラクティブな WEB アプリケーションを構築するために重要です。この記事では、PHP 変数を詳しく説明し、10 個の実際の例を使用して実際に動作する様子を示します。 1. ユーザー入力の保存 $username=$_POST["username"];$passWord=$_POST["password"]; この例では、フォーム送信からユーザー名とパスワードを抽出し、その後の処理のために変数に保存します。 2. 構成値 $database_host="localhost";$database_username="username";$database_pa を設定します。

タイトル: 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 データ構造はプログラミングにおいて重要な役割を果たし、プログラミングの基礎です。 Go 言語には、一般的に使用されるデータ構造が多数あり、これらのデータ構造の実装をマスターすることは、優れたプログラマーになるために重要です。この記事では、Go 言語で一般的に使用されるデータ構造を紹介し、読者がこれらのデータ構造を使い始めて習熟するのに役立つ、対応するコード例を示します。 1. 配列 配列は基本的なデータ構造であり、同じ型のグループです。

Java バブル ソートの最も簡単なコード例 バブル ソートは一般的な並べ替えアルゴリズムであり、その基本的な考え方は、並べ替える順序を、隣接する要素の比較と交換を通じて順序付けされた順序に徐々に調整することです。次に、バブル ソートの実装方法を示す簡単な Java コード例を示します。 publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

「Go 言語プログラミングの例: Web 開発におけるコード例」 インターネットの急速な発展に伴い、Web 開発はさまざまな業界で不可欠な部分になりました。 Go 言語は、強力な機能と優れたパフォーマンスを備えたプログラミング言語として、Web 開発の開発者にますます好まれています。この記事では、読者が Go 言語をより深く理解し、Go 言語を使用して独自の Web アプリケーションを構築できるように、具体的なコード例を通じて Web 開発に Go 言語を使用する方法を紹介します。 1. シンプルな HTTP サーバー まず、

PHP を使用して在庫管理システムの在庫管理機能コードを記述する方法 在庫管理は多くの企業にとって不可欠な部分です。複数の倉庫を持つ企業にとって、在庫管理機能は特に重要です。在庫を適切に管理および追跡することで、企業は異なる倉庫間で在庫を割り当て、運用コストを最適化し、コラボレーション効率を向上させることができます。この記事では、PHP を使用して在庫倉庫管理機能のコードを記述する方法を紹介し、関連するコード例を示します。 1. 在庫倉庫管理機能のコードを書き始める前に、データベースを確立します。

Java 選択ソート方法のコード記述ガイドと例 選択ソートは、シンプルで直観的なソート アルゴリズムです。そのアイデアは、ソートされていない要素から毎回最小 (または最大) の要素を選択し、すべての要素がソートされるまで交換することです。この記事では、選択項目の並べ替えのためのコード作成ガイドを提供し、特定の Java サンプル コードを添付します。アルゴリズム原理 選択ソートの基本原理は、ソート対象の配列をソート済み部分とソートされていない部分の 2 つの部分に分割し、その都度、未ソート部分から最小 (または最大) の要素が選択され、ソート済み部分の最後に配置されます。上記を繰り返します

Huawei クラウド エッジ コンピューティング相互接続ガイド: インターフェイスを迅速に実装するための Java コード サンプル IoT テクノロジーの急速な発展とエッジ コンピューティングの台頭により、ますます多くの企業がエッジ コンピューティングのアプリケーションに注目し始めています。 Huawei Cloud はエッジ コンピューティング サービスを提供し、企業に信頼性の高いコンピューティング リソースと便利な開発環境を提供し、エッジ コンピューティング アプリケーションの実装を容易にします。この記事では、Java コードを通じて Huawei Cloud エッジ コンピューティング インターフェイスを迅速に実装する方法を紹介します。まずは開発環境を準備する必要があります。 Java Development Kit がインストールされていることを確認してください (
