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

PHP 配列を使用して、無制限の分類、データベースなし、再帰なしを実現します。_PHP チュートリアル

WBOY
リリース: 2016-07-21 15:59:06
オリジナル
765 人が閲覧しました

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


class cat
{
public $data;

public function __construct()
{
@include "data.php";
$this->data = $class;
}


パブリック 関数 CreateSortLevel($fatherlevel)
{
if(empty($fatherlevel))

if(is_array($this-&g) t;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";
}
}

パブリック関数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 function 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 "
";
終了します。
}

foreach($cat->orders() as $value)
{
$level = strlen(substr($value['sortlevel'],0,-3));
for($i = 0; $i < $level; $i++)
{
echo "-";
}
echo $value["sortname"];
エコー "
";
}
?>

www.bkjia.com本当http://www.bkjia.com/PHPjc/317449.html技術記事例: ?php classcat { public$data; } publicfunction__construct() { @include"data.php"; $this-data=$class; publicfunctionCreateSortLevel($fatherlevel) { if(empt...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート