ホームページ  >  記事  >  バックエンド開発  >  PHPTree - php は無制限のclassifications_php スキルを迅速に生成します

PHPTree - php は無制限のclassifications_php スキルを迅速に生成します

不言
不言オリジナル
2018-04-04 10:20:324449ブラウズ

ツリーデータは、典型的なツリー構造である無限多レベル分類など、開発でよく使用されます。ここでのアルゴリズムは再帰的思考を使用しており、開発プロセスを簡素化するために、開発効率を向上させるツールを作成しました

それは PHPTree です。

git アドレス: https://git.oschina.net/jiusem/PHPTree.git

または、スクリプト ホーム http://www.jb51.net/codes/606002.html からダウンロードします

最も単純な例:

<?php 
require(&#39;PHPTree.class.php&#39;);

//原始数据, 从数据库读出
$data = array(
	array(
		&#39;id&#39;=>1,
		&#39;name&#39;=>&#39;book&#39;,
		&#39;parent_id&#39;=>0
	),
	array(
		&#39;id&#39;=>2,
		&#39;name&#39;=>&#39;music&#39;,
		&#39;parent_id&#39;=>0
	),
	array(
		&#39;id&#39;=>3,
		&#39;name&#39;=>&#39;book1&#39;,
		&#39;parent_id&#39;=>1
	),
	array(
		&#39;id&#39;=>4,
		&#39;name&#39;=>&#39;book2&#39;,
		&#39;parent_id&#39;=>3
	)
);

$r = PHPTree::makeTree($data);
echo json_encode($r);

?>

出力:

[
0,
"expanded": false, //子ノードを展開しません
"children": 「parent_id」: 1,
"" "expanded": false ,
" "children": [
" " " "id ": 4,
" name ":" book2 ",
" Parent_id ": 3,
" Leaf ": true
}
]}
]},
{

" "" ": "music",
"parent_id": 0,
"leaf": true
"" }
]



生成されたデータはツリー構造であり、 ExtJS などのフロントエンド フレームワーク。 Git には ExtJS のデモが含まれており、参照できます。

デモ:





フロントエンドフレームワークを使用する必要がなく、HTML で出力するだけの場合は、次のメソッドを使用できます。

$r = PHPTree::makeTreeForHtml($data);

一次元配列を取得し、level フィールドを使用して分類のレベルを識別します:

array(
 array(
  &#39;id&#39;=>1,
  &#39;name&#39;=>&#39;用户管理&#39;,
  &#39;parent_id&#39;=>0,
  &#39;level&#39;=>0 //一级分类
 ),
 array(
  &#39;id&#39;=>1,
  &#39;name&#39;=>&#39;用户列表&#39;,
  &#39;parent_id&#39;=>1,
  &#39;level&#39;=>1 //二级分类
 )
 ....
);

選択タグとして出力:

echo &#39;<h1>PHPTree树形结构</h1>&#39;;
echo &#39;<select style="width:300px;">&#39;;
foreach($r as $item){
	echo &#39;<option>&#39;;
	//根据所在的层次缩进
	echo str_repeat(&#39;......&#39;,$item[&#39;level&#39;]);
	echo $item[&#39;name&#39;];
	echo &#39;</option>&#39;;
}
echo &#39;</select>&#39;;

デモ:

Git にはHTMLを出力するデモがありますので参考にしてください。

データベースの設計に関しては、データ生成に影響を与えずに他のフィールドを自分で追加できることを確認するだけで済みます。 parent_id は親 ID であり、第 1 レベルの分類の場合は 0 に設定します。もちろん、フィールドも構成可能です。高度な活用方法を紹介しますので、ぜひ読んでみてください。

子ノードを展開します:

PHPTree::makeTree( $data, array(
 &#39;expanded&#39; => true
));

输出的数据为:

[
        {
            id:1,
            name:'book1',
            expanded:true,//展开子节点
            children:[
                ...
            ]
        }
]

自定义主键和父键:

//数据库读出
$data = array(
 array(
  &#39;order_id&#39;=>1, //主键
  &#39;name&#39;=>&#39;book1&#39;,
  &#39;pid&#39;=>0, //父键
  ...
 )
);
PHPTree::makeTree( $data, array(
 &#39;primary_key&#39; => &#39;order_id&#39;,
 &#39;parent_key&#39; => &#39;pid&#39;
));

输出的数据为:

[
        {
            order_id:1,
            name:'book1',
            pid:0,
            ...
        }
]

makeTreeForHtml 方法也支持配置主键和父键。

还有其他字段也可以自定义,但下面这些参数仅支持 makeTree 方法:

$r = PHPTree::makeTree($data, array(
 &#39;expanded_key&#39; => &#39;expanded&#39;,
 &#39;children_key&#39; => &#39;children&#39;,
 &#39;leaf_key&#39;  => &#39;leaf&#39;
));

默认,这些字段的配置都是以ExtJS为参考的,如果你使用zTree框架的话,这些字段就需要重新配置了。

zTree 是一款强大的国产树形框架,它还支持 简单JSON格式,是一维数据格式,实际上就不需要用到PHPTree了。当然,PHPTree输出的数据层次感清晰,zTree也是支持的。

相关推荐:

php递归实现无限级分类的开发过程及示例代码

php 实现无限级分类的三种方式

php无限级分类实现方法分析

以上がPHPTree - php は無制限のclassifications_php スキルを迅速に生成しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。