美文网首页
无限级分类与php数组函数学习

无限级分类与php数组函数学习

作者: myFamily329 | 来源:发表于2017-07-30 15:38 被阅读0次

    获取用户个人的物品类型侧菜单栏

    • 功能要求描述
      现在项目涉及物品的类型,其实是无限级分类的处理,但是项目要求不仅要获取所有的物品类型的分类的无限级展示,还要可以获取到用户个人的无限级分类。
    • 面临问题
      用户发布物品时,选择物品类型,其实前端提交的是类型的typeId,如果用户选择了类型中的子分类,其中所有的美物中都未涉及此子分类的父级分类,想要使所有的分类可以在前端显示时,有一级,二级等标题之分,要使用无限级分类的函数进行处理时,但针对此情况就会发生数据的丢失。
    • 问题解决
      思路:先通过连表查询获取用户的所有物品类型,之后遍历数据或许两个id的数组$pid[],$child[],这样就获取了所有物品类型中,无父级类型的子类型。之后在$pid[]中去掉==0的情况,之后合并两个数组,再array_unique的数组,之后获取仔获取所有信息,之后再使用无限级分类函数。问题就可以解决了!
    $typesInfo=$type->field('a.*')->alias('a')->join('LEFT JOIN cu_collection b ON b.typeId=a.typeId')
     ->group('a.typeId')->where(array('userId'=>$userId))->select();
    /**
             * 1.在添加美物类型时,会只选到子类型,并无父级类型
             * 2.之后循环遍历,取得父类型
             */
            foreach($typesInfo as $item) {
                $pid[]= $item['pid'];
                $chilid[]=$item['typeid'];
            }
            //去除id==0
            foreach($pid as $k=>$v){
                if($v==0){
                    unset($pid[$k]);
                }
            }
            $mergeId=array_merge($pid,$chilid);
            $resultId=array_unique($mergeId);
            foreach($resultId as $item){
                $resultType[]=$type->where(['typeid='.$item])->find();
            }
            //对获取的类别进行一级二级的展示
            $result=$this->resort($resultType);
    

    问题解决中学到的知识点

    • PHP数组函数序列之array_unique() - 去除数组中重复的元素值
    • PHP删除一维数组中某一个值元素的操作 unset()
      http://www.jb51.net/article/39401.htm
      使用array_splice()删除特定值和使用unset删除特定值是有区别的。
      array_splice()函数删除的话,数组的索引值也变化了。
      unset()函数删除的话,数组的索引值没有变化。
    <?php
    $arr1 = array(1,3, 5,7,8);
    $key = array_search(3, $arr1);
    if ($key !== false)
        array_splice($arr1, $key, 1);
    var_dump($arr1);
    ?>
    

    输出为:

    array(4) { [0]=> int(1) [1]=> int(5) [2]=> int(7) [3]=> int(8) }
    
    • PHP array_push() 函数 array_push()
      函数向第一个参数的数组尾部添加一个或多个元素(入栈),然后返回新数组的长度。
      该函数等于多次调用 $array[] = $value。
    终于解决了一个困扰我好久的一个问题,开心,好好学习,天天向上,是对的!!!

    总结

    2017年7月30日 好好学习,天天向上,今天也是。

    相关文章

      网友评论

          本文标题:无限级分类与php数组函数学习

          本文链接:https://www.haomeiwen.com/subject/aetklxtx.html