• 获取联级下拉栏目


    在数据库里有如下数据:其中子分类为零的为主导航, 将下面的栏目在前台显示出来,如下效果

    .tpl如下:

    <tr><td>栏  目:<select name="nav"><option style="padding: 0;">请选择一个栏目类别</option>{$nav}</select></td></tr>

     下面演示如何使数据在前台显示出:

    1 两个要用的数据库函数如下:是navModel对象的成员函数

            //查询所有主导航,没有limit
            public function getAllFrontNav(){
                $_sql = "select id,nav_name,nav_info,sort from cms_nav where pid=0 order by sort asc";
                return parent::all($_sql);
            }
            //查询所有子导航
            public function getAllChildNav(){
                $_sql = "select id,nav_name,nav_info,sort from cms_nav where pid=$this->id order by sort asc $this->limit";
                return parent::all($_sql);
            }

    2 实现前台样式如下:重点在此,利用循环,再注入变量

            private function add(){
                $_nav = new NavModel();
                foreach ($_nav->getAllFrontNav() as $_object){
                    $_html .= '<optgroup label="'.$_object->nav_name.'">';
                    $_nav->id = $_object->id;//得到主导航的id用来查找它的子导航
                    if (!!$_childnav = $_nav->getAllChildFrontNav()){
                        foreach ($_childnav as $_object){
                            $_html .= '<option>'.$_object->nav_name.'</option>';
                        }
                    }
                    $_html .= '</optgroup>';
                }
                $this->_tpl->assign('nav',$_html);
            }

    3 简单的css样式自行修改了

  • 相关阅读:
    c++ set unordered_set区别
    LeetCode 213. 打家劫舍 II
    LeetCode 152. 乘积最大子序列
    [HAOI 2012] 外星人
    [HAOI 2016] 找相同字符
    [ZJOI2007] 仓库建设
    [SCOI 2016] 美味
    [BZOJ 2127] Happiness
    [NOI2009] 植物大战僵尸
    [SDOI 2016] 数字配对
  • 原文地址:https://www.cnblogs.com/by-dxm/p/6286788.html
Copyright © 2020-2023  润新知