• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点示例

    本文实例讲述了Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点。分享给大家供大家参考,具体如下:

    list_to_tree 使用起来十分方便,详细可查看手册。因为我在用的时候需要同时列出所有节点,所以写了一个递归函数,拿出来供大家参考。

    public function index(){
      Load('extend');      //加载扩展方法
      $Category=D('Category');
      $list=$Category->order('sort desc')->select();//实现同级节点排序
      $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 (isset($val['_child'])){
              $this->findChild($val['_child']);
            }
          }
      return $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)) {
        // 创建基于主键的数组引用
        $refer = 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];
          }else{
            if (isset($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 = $resultSet = array();
        foreach ($list as $i => $data)
          $refer[$i] = $data[$field];
        switch ($sortby) {
          case 'asc': // 正向排序
            asort($refer);
            break;
          case 'desc':// 逆向排序
            arsort($refer);
            break;
          case 'nat': // 自然排序
            natcasesort($refer);
            break;
        }
        foreach ( $refer as $key=> $val)
          $resultSet[] = $list[$key];
        return $resultSet;
      }
      return false;
    }
    
    /**
     * 在数据列表中搜索
     * @access public
     * @param array $list 数据列表
     * @param mixed $condition 查询条件
     * 支持 array('name'=>$value) 或者 name=$value
     * @return array
     */
    function list_search($list,$condition) {
      if(is_string($condition))
        parse_str($condition,$condition);
      // 返回的结果集合
      $resultSet = array();
      foreach ($list as $key=>$data){
        $find  =  false;
        foreach ($condition as $field=>$value){
          if(isset($data[$field])) {
            if(0 === strpos($value,'/')) {
              $find  =  preg_match($value,$data[$field]);
            }elseif($data[$field]==$value){
              $find = true;
            }
          }
        }
        if($find)
          $resultSet[]   =  $list[$key];
      }
      return $resultSet;
    }
    
    

    更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。

    希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

    您可能感兴趣的文章:
    • thinkphp5实现无限级分类
    • 使用ThinkPHP的自动完成实现无限级分类实例详解
    • Thinkphp无限级分类代码
    • ThinkPHP无限级分类原理实现留言与回复功能实例
    • ThinkPHP自动填充实现无限级分类的方法
    • thinkphp框架无限级栏目的排序功能实现方法示例
    • thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法
    • thinkphp实现无限分类(使用递归)
    • ThinkPHP实现递归无级分类——代码少
    上一篇:thinkphp框架表单数组实现图片批量上传功能示例
    下一篇:thinkphp框架实现路由重定义简化url访问地址的方法分析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点示例 Thinkphp,框架,使用,list,tree,