다음 편집자는 ThinkPHP+EasyUI의 ComboTree에서 회계 트리 메뉴를 구현하는 방법에 대한 기사를 가져올 것입니다. 에디터가 꽤 좋다고 생각해서 지금 공유해서 참고용으로 올려보겠습니다. 편집기를 따라 살펴보겠습니다
데이터베이스의 회계 데이터 테이블의 필드가 id, code, name, islast라고 가정합니다. 자동 증가 기본 키, 계정 코드, 계정 이름, 최종 수준 계정인지 여부("1"은 최종 수준 계정을 나타냄)입니다.
여기에서는 Thinkphp의 모델 계층에서 재귀를 사용하여 ComboTree에 필요한 데이터를 구축합니다. 코드와 주석은 다음과 같습니다.
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; } }
위의 데이터와 유사합니다(예: 부서, 지역) 등) 트리 모양을 만들어야 합니다. 기본적으로 메뉴 코드만 수정하면 유사한 기능을 구현할 수 있습니다.
위 내용은 ThinkPHP+EasyUI의 ComboTree에서 회계 트리 메뉴 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!