本篇文章主要介紹php無限極分類的方法,感興趣的朋友參考下,希望對大家有所協助。
代碼如下:
<?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;}
總結:以上就是本篇文的全部內容,希望能對大家的學習有所協助。
相關推薦:
基於thinkPHP實現的自訂分享功能的方法
php版發紅包介面用法執行個體
php基於glob函數實現遍曆檔案和目錄詳解