标签:htm dna mit 实现 ret 样式 选择 查询 分类
在数据库里有如下数据:其中子分类为零的为主导航, 将下面的栏目在前台显示出来,如下效果
.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样式自行修改了
标签:htm dna mit 实现 ret 样式 选择 查询 分类
原文地址:http://www.cnblogs.com/by-dxm/p/6286788.html