이 글에서는 ThinkPHP와 EasyUI의 ComboTree를 사용하여 회계 계정 트리 메뉴를 생성하는 구현 방법을 주로 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 그것이 모두에게 도움이 되기를 바랍니다.
데이터베이스의 회계 데이터 테이블 필드가 id, code, name, islast라고 가정합니다. 자동 증가 기본 키, 계정 코드, 계정 이름, 최종 수준 계정인지 여부("1"은 최종 수준 계정을 나타냄)입니다.
여기서 ComboTree에 필요한 데이터를 구축하기 위해 Thinkphp의 모델 계층에서 재귀가 사용됩니다.
namespace Home\Model; use Think\Model; class AccountModel extends Model{ public function getTreeList(){ $data = $this->field('id,code,name,islast')->select(); foreach($data as &$v){ //这里加入了元素pid,用来标识父级id的 $len = strlen($v['code']); if($len == 3){ //这里假设长度为3位的科目编码是一级,5位为二级科目,7位为三级,以此类推 $v['pid'] = 0; } else { $v['pid'] = substr($v['code'],0,$len-2); } } return $this->createTree($data); //生成ComboTree所需的数据结构 } //递归的方式生成子树 private function createSubTree($data,$pid){ $tree = array(); foreach($data as $k=>$v){ if($v['pid'] == $pid){ $newDate = array( 'id' => $v['id'], 'text'=>$v['name'], 'state'=>($v['islast'] != 1)?'closed':'open' ); if($v['islast'] != 1){ //如果不是末级科目调用自身生成子数据 $subData = $this->createSubTree($data,$v['code']); if(!empty($subData)){ $newDate['children'] = $subData; } } array_push($tree,$newDate); } } return $tree; } //生成树,先从一级会计科目分类开始创建树形菜单数据 private function createTree($data){ $ret = array(); foreach($data as $k => $v){ if($v['pid'] == 0){ $newDate = array( //创建为ComboTree能够识别的格式,这里我没有更好的办法了,只能这样处理 'id' => $v['id'], 'text'=>$v['name'], 'state'=>'closed' ); $subData = $this->createSubTree($data,$v['code']); if(!empty($subData)){ $newDate['children'] = $subData; } $ret[] = $newDate; } } return $ret; } }
위의 데이터와 유사합니다(예: 부서, 지역 등). ), 트리 메뉴를 구성하려면 간단한 수정이 필요합니다. 기본적으로 코딩 후에는 유사한 기능을 구현할 수 있습니다.例 관련 권장 사항: 详 예제 ThinkPHP5 URL 및 라우팅 기능에 대한 자세한 설명
위 내용은 ThinkPHP는 EasyUI를 사용하여 회계 트리 메뉴를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!