如何在php中利用smarty模板实现一个无限极分类?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
具体如下:
<?php
$conn = mysql_connect("localhost","admin","admin");
mysql_select_db("people_shop",$conn);
mysql_query("SET NAMES 'UTF-8'");
$class_arr=array();
$sql = "select * from ecs_brand ORDER BY brand_id asc ";
$query = mysql_query($sql);
while($row = mysql_fetch_array($query)){
$class_arr[] = array($row['brand_id'],$row['brand_name'],$row['parent_id'],$row['sort_order']);
}
function dafenglei_select($m,$id,$index)
{
global $class_arr;
global $str;
$n = str_repeat(" ",$m);
// $n = $m;
for($i=0;$i<count($class_arr);$i++){
if($class_arr[$i]['2']==$id){
if($class_arr[$i]['0']==$index){
$str.= "<option value=\"".$class_arr[$i][0]."\" selected=\"selected\">".$n.$class_arr[$i][1]."</option>\n";
}else{
$str.= "<option value=\" ".$class_arr[$i][0]."\">".$n.$class_arr[$i][1]."</option>\n";
}
dafenglei_select($m+1,$class_arr[$i][0],$index);
}
}
return $str;
}
$aa = dafenglei_select(1,0,0);
?>
<select name="parent_id">
<option value='0'>顶级分类</option>
<?php
echo $aa;
?>
</select>
如果是用smarty的话
再加一个
复制代码 代码如下:
$smarty->assign('wuxian_class',$aa);
在html页面加上这句就可以了
<select name="parent_id">
<option value='0'>顶级分类</option>
{$wuxian_class}
</select>
还有一个问题要注意 $str必须要是global行的,否则会有错误。
无限极分类的延伸:
我们可以写一个函数,每次调用这个函数的时候我们只需要传入这个数组及数据,就可以调用了,下面是我写的一个方法。
function dafenglei_select(& $arr=array(),$m,$id,$index)
{
// global $class_arr;
global $str;
$n = str_repeat(" ",$m);
// $n = $m;
for($i=0;$i<count($arr);$i++){
if($arr[$i]['2']==$id){
if($arr[$i]['0']==$index){
$str.= "<option value=\"".$arr[$i][0]."\" selected=\"selected\">".$n.$arr[$i][1]."</option>\n";
}else{
$str.= "<option value=\" ".$arr[$i][0]."\">".$n.$arr[$i][1]."</option>\n";
}
dafenglei_select($arr,$m+1,$arr[$i][0],$index);
}
}
return $str;
}
调用只需要这样就行了:
复制代码 代码如下:
$aa = dafenglei_select($class_arr,0,0,0);
看完上述内容,你们掌握如何在php中利用smarty模板实现一个无限极分类的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。