新手,写了基本功能,未写排序等相关操作;求高手改进,
数据库:
类库文件:
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元

了解Python编程的入门级代码示例Python是一种简单易学,功能强大的编程语言。对于初学者来说,了解Python编程的入门级代码示例是非常重要的。本文将为您提供一些具体的代码示例,帮助您快速入门。打印HelloWorldprint("HelloWorld")这是Python中最简单的代码示例。print()函数用于将指定的内容输出

PHP变量存储程序运行期间的值,对于构建动态且交互式的WEB应用程序至关重要。本文将深入探讨php变量,并通过10个真实的示例展示它们的实际应用。1.存储用户输入$username=$_POST["username"];$passWord=$_POST["password"];此示例从表单提交中提取用户名和密码,并将其存储在变量中以供进一步处理。2.设置配置值$database_host="localhost";$database_username="username";$database_pa

Java冒泡排序最简单的代码示例冒泡排序是一种常见的排序算法,它的基本思想是通过相邻元素的比较和交换来将待排序序列逐步调整为有序序列。下面是一个简单的Java代码示例,演示了如何实现冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

标题:从入门到精通:Go语言中常用数据结构的代码实现数据结构在编程中起着至关重要的作用,它是程序设计的基础。在Go语言中,有许多常用的数据结构,掌握这些数据结构的实现方式对于成为一名优秀的程序员至关重要。本文将介绍Go语言中常用的数据结构,并给出相应的代码示例,帮助读者从入门到精通这些数据结构。1.数组(Array)数组是一种基本的数据结构,是一组相同类型

《Go语言编程实例:Web开发中的代码示例》随着互联网的快速发展,Web开发已经成为各行业中必不可少的一部分。作为一门功能强大且性能优越的编程语言,Go语言在Web开发中越来越受到开发者们的青睐。本文将通过具体的代码示例,介绍如何利用Go语言进行Web开发,让读者能够更好地理解和运用Go语言来构建自己的Web应用。1.简单的HTTP服务器首先,让我们从一个

如何使用PHP编写库存管理系统中的库存分仓管理功能代码库存管理是许多企业中不可或缺的一部分。对于拥有多个仓库的企业来说,库存分仓管理功能尤为重要。通过合理管理和跟踪库存,企业可以实现不同仓库之间的库存调拨,优化运营成本,改善协同效率。本文将介绍如何使用PHP编写库存分仓管理功能的代码,并为您提供相关的代码示例。一、建立数据库在开始编写库存分仓管理功能的代码之

Java选择排序法代码编写指南及示例选择排序是一种简单直观的排序算法,其思想是每次从未排序的元素中选择最小(或最大)的元素进行交换,直到所有元素排序完成。本文将提供选择排序的代码编写指南,并附上具体的Java示例代码。算法原理选择排序的基本原理是将待排序数组分为已排序和未排序两部分,每次从未排序部分选择最小(或最大)的元素,将其放到已排序部分的末尾。重复上述

华为云边缘计算对接指南:Java代码示例快速实现接口随着物联网技术的快速发展和边缘计算的兴起,越来越多的企业开始关注边缘计算的应用。华为云提供了边缘计算服务,为企业提供了高可靠的计算资源和便捷的开发环境,使得边缘计算应用更加容易实现。本文将介绍如何通过Java代码快速实现华为云边缘计算的接口。首先,我们需要准备好开发环境。确保你已经安装了Java开发工具包(


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Dreamweaver Mac版
시각적 웹 개발 도구

뜨거운 주제



