ホームページ > バックエンド開発 > PHPチュートリアル > PHP 配列を使用して無制限の分類を実現し、データベースも再帰も必要ありません

PHP 配列を使用して無制限の分類を実現し、データベースも再帰も必要ありません

WBOY
リリース: 2016-07-29 08:35:38
オリジナル
1000 人が閲覧しました

コードをコピーします コードは次のとおりです:


class cat
{
public $data;
パブリック 関数 __construct()
{
@include "data.php";
$this->data = $class;
}
public function CreateSortLevel($fatherlevel)
{
if(empty($fatherlevel))
{
if(is_array($this->data))
{
$fast_level = array();
foreach($this->data as $value)
{
if(strlen($value["sortlevel"]) == 3)
{
$fast_level[] = $value["sortlevel"];
}
}
$max_fast_level = max($fast_level);
unset($fast_level);
$sub = ceil($max_fast_level) + 1;
switch(strlen($sub))
{
case 1:
return "00{$sub}";
休憩;
ケース 2:
return "0{$sub}";
休憩;
ケース 3:
$sub を返す。
休憩;
}
}
else
{
return "001";
}
}
foreach($this->data as $val)
{
if(eregi("^".$fatherlevel.".{3}$",$val["ソートレベル"]))
{
$level[] = $val["ソートレベル"];

if(is_array($level) )
{
$max_two_level = max($レベル);
$sub = ceil(substr($max_two_level,-3)) + 1;
switch(strlen($sub))
ケース 1:
return substr($max_two_level,0,strlen($max_two_level) -1).$sub;
break;
substr($max_two_level,0,strlen($max_two_level)-2)
break;
case 3:
return substr($max_two_level,0 ,strlen($max_two_level)-3).$sub;
break
}
else
return $fatherlevel."001";
}
}
public orders()
{
$op = $ this->data;
$this->array_usort($op,"sortlevel",SORT_ASC);
$op;
public function add_cat($sortname,$sortlevel)
{
$data = 時間( );
$arr = 配列
(
"{$data}" => 配列
(
"ソート名" => $ソート名,
"sortlevel" => $this->CreateSortLevel($sortlevel)
)
);
$rs = $this->data + $arr;
$this->add_wirte($rs);
}
プライベート 関数 array_usort(&$array)
{
$args = func_get_args();
for($i=1,$cmd='',$size=count($args);$i<$size;$i++)
{
$num = $i;
$order = "";
$con = "@strcmp($a['$args[$num]'],$b['$args[$num]'])";
while(++$i < $size)
{
if($args[$i] === SORT_NUMERIC)
{
{ $con = "($a['$args[$num]']-$ b['$args[$num]'])";
}
else if($args[$i] === SORT_DESC)
{
$order = "-1*" ;
}
else if(is_string($args[$i]))
{
$i--;
休憩。
}
}
$cmd .= "if($num = $con)return $order$num;else ";
if($order != '')
{
$i++;
}
}
@usort($array,@create_function('$a,$b',"$cmd return 0;"));
}
public function wirte($sortname,$sortlevel)
{
$array = " $array .= '$class = array'."rn(rn";
$array .= ' "'.time().'" => array'."rn";
$array .= ' ( '."rn";
$array .= ' "sortname" => "'.$sortname.'.",rn"; ->CreateSortLevel($sortlevel).'"'."rn";
$array .= ' )'."rn";
$array .= ")rn?>";
file_put_contents("data.php",$array);
}
public add_wirte($rs)
{
$array = " $array .= '$class = array'."rn(rn";
foreach($rs as $key=>$value)
{
$array .= "rn"; $array .= ' " '.$key.'" => array'."rn";
$array .= ' ('."rn";
$array .= ' "sortname" => "'.$value["sortname "].'"'.",rn"
$array .= ' "'.$value["sortlevel"].'"'."rn"; ,';
$array = substr($array,0,-1);
$array .= "rn)rn?>";
file_put_contents("data.php",$array);
}
}
$cat = 新しい cat();
if($_GET["action"] == "add")
{
if(strlen($_POST["sortname"]) < 2)
{
echo '';
echo '';
終了します。
}
if(file_exists("data.php"))
{
$cat->add_cat($_POST["sortname"],$_POST["sortlevel"]);
echo '';
echo '';
終了します。
}
else
{
$cat->wirte($_POST["sortname"],$_POST["sortlevel"]);
echo '';
echo '';
終了します。
終了します。
}
}
if($_GET["action"] == "tpl")
{
echo '

';"rn";
echo 'rn";
echo ' '."rn";
echo '';
echo "
";
exit;
}
foreach($cat->orders() as $value)
{
$level = strlen(substr($value['sortlevel'],0,-3));
for($i = 0; $i {
echo "-" }
echo $value["sortname"];
echo "
"
?>
上記では、データベースや再帰を使用せずに無制限の分類を実現するための PHP 配列の使用方法を、その内容も含めて紹介しました。PHP チュートリアルに興味のある友人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート