ホームページ >バックエンド開発 >PHPチュートリアル >PHPにおける無制限分類の表示問題。一日中悩んでいるのですが、全く分かりません。
機能:
//无限分类显示函数function get_str($id = 0) { global $str; $sql = "select classid,classname,classstate,classtype,classurl,classpage,classorder,classtitle,classkeyword,classdescription,classpid from bz_class where classpid= $id"; $result = mysql_query($sql);//查询pid的子类的分类 if($result && mysql_affected_rows()){//如果有子类 while ($row = mysql_fetch_array($result)) { //循环记录集 $str.= "<tr><td>" .$row['classid']. "</td><td>". $row['classname']. "<p>ID: 882233</p></td><td>". $row['classtype']."</td><td>". $row['classid']."</td><td>". $row['classid']."</td><td>". $row['classid']."</td></tr>" ; //字符串构建 get_str($row['classid']); //调用get_str(),将记录集中的id参数传入函数中,继续查询下级 } } return $str; }
Try
//无限分类显示函数function get_str($id = 0, $depth=0) { global $str; $sql = "select classid,classname,classstate,classtype,classurl,classpage,classorder,classtitle,classkeyword,classdescription,classpid from bz_class where classpid= $id"; $result = mysql_query($sql);//查询pid的子类的分类 if($result && mysql_affected_rows()){//如果有子类 while ($row = mysql_fetch_array($result)) { //循环记录集 $str.= "<tr><td>" .$row['classid']. "</td><td>".str_repeat ( "└" ,$depth). $row['classname']. "<p>ID: 882233</p></td><td>". $row['classtype']."</td><td>". $row['classid']."</td><td>". $row['classid']."</td><td>". $row['classid']."</td></tr>" ; //字符串构建 get_str($row['classid'], $depth+1); //调用get_str(),将记录集中的id参数传入函数中,继续查询下级 } } return $str; }
get_str($row['classid']) // get_str() を呼び出し、レコードセットの id パラメータを関数に渡します。引き続き下位レベルのクエリを実行します
この文によって返される $str は使用されません。
参考: http://www.jb51.net/article/36220.htm
試してみてください
//无限分类显示函数function get_str($id = 0, $depth=0) { global $str; $sql = "select classid,classname,classstate,classtype,classurl,classpage,classorder,classtitle,classkeyword,classdescription,classpid from bz_class where classpid= $id"; $result = mysql_query($sql);//查询pid的子类的分类 if($result && mysql_affected_rows()){//如果有子类 while ($row = mysql_fetch_array($result)) { //循环记录集 $str.= "<tr><td>" .$row['classid']. "</td><td>".str_repeat ( "└" ,$depth). $row['classname']. "<p>ID: 882233</p></td><td>". $row['classtype']."</td><td>". $row['classid']."</td><td>". $row['classid']."</td><td>". $row['classid']."</td></tr>" ; //字符串构建 get_str($row['classid'], $depth+1); //调用get_str(),将记录集中的id参数传入函数中,继续查询下级 } } return $str; }