本文实例讲述了thinkphp框架使用list_to_tree 实现无限级分类列出所有节点。分享给大家供大家参考,具体如下:
list_to_tree 使用起来十分方便,详细可查看手册。因为我在用的时候需要同时列出所有节点,所以写了一个递归函数,拿出来供大家参考。
public function index(){ load('extend'); //加载扩展方法 $category=d('category'); $list=$category->order('sort desc')->lect();//实现同级节点排序 $list=list_to_tree($list,'id','fid'); //详细参数见手册 $list=$this->findchild($list); dump($list);}protected function findchild($arr){ static $tree=array(); foreach ($arr as $key=>$val){ $tree[]=$val; if (ist($val['_child'])){ $this->findchild($val['_child']); } } r宋词十大名篇eturn $tree;}
/** * 把返回的数据集转换成tree * @access public * @param array $list 要转换的数据集 * @param string $pid parent标记字段 * @param string $level level标测试题大全记字段 * @return array */function list_to_tree($list, $pk='id',$pid = 'pid',$child = '_child',$root=0) { // 创建tree $tree = array(); if(is_array($list)) { // 创建基于主键的数组引用 $refe网页证书错误怎么办r = array(); foreach ($list as $key => $data) { $refer[$data[$pk]] =& $list[$key]; } foreach ($list as $key => $data) { // 判断是否存在parent $parentid = $data[$pid]; if ($root == $parentid) { $tree[] =& $list[$key]; }el{ aps审核 if (ist($refer[$parentid])) { $parent =& $refer[$parentid]; $parent[$child][] =& $list[$key]; } } } } return $tree;}/** * 对查询结果集进行排序 * @access public * @param array $list 查询结果 * @param string $field 排序的字段名 * @param array $sortby 排序类型 * asc正向排序 desc逆向排序 nat自然排序 * @return array */function list_sort_by($list,$field, $sortby='asc') { if(is_array($list)){ $refer = $resultt = array(); foreach ($list as $i => $data) $refer[$i] = &$data[$field]; switch (自己的文章$sortby) { ca 'asc': // 正向排序 asort($refer); break; ca 'desc':// 逆向排序 arsort($refer); break; ca 'nat': // 自然排序 natcasort($refer); break; } foreach ( $refer as $key=> $val) $resultt[] = &$list[$key]; return $resultt; } return fal;}/** * 在数据列表中搜索 * @access public * @param array $list 数据列表 * @param mixed $condition 查询条件 * 支持 array('name'=>$value) 或者 name=$value * @return array */function list_arch($list,$condition) { if(is_string($condition)) par_str($condition,$condition); // 返回的结果集合 $resultt = array(); foreach ($list as $key=>$data){ $find = fal; foreach ($condition as $field=>$value){ if(ist($data[$field])) { if(0 === strpos($value,'/')) { $find = preg_match($value,$data[$field]); }elif($data[$field]==$value){ $find = true; } } } if($find) $resultt[] = &$list[$key]; } return $resultt;}
本文发布于:2023-04-08 16:40:20,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/e23d4643c3f12b1af0271160e35874d6.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:Thinkphp框架使用list.doc
本文 PDF 下载地址:Thinkphp框架使用list.pdf
留言与评论(共有 0 条评论) |