php mysql怎么获取网站的所有栏目树状结构?给你个原理吧
先找第一层
然后在里面递归获取下一层的
如果你知道递归怎么写的应该就明白了
PHP的数据类型有哪些?每种数据类型适用于哪些应用场合?借用“短发人”php树形数据结构的样式的数据,手工完善一下 。
boolean (布尔型)一般用于判断,true或false 。比如是否检测 , 是否完成,是否毕业等 。
integer (整型)一般用于年龄,数量等没有小数点php树形数据结构的样式的计算 。比如1 2 33 -9等 。
float (浮点型, 也称作 double) 一般用于金钱 , 面积、体积等科学,含小数点的计算 。比如3.1415926585897932
string (字符串)一般用于人名,物品等常规字符串 。比如“张三”“桌子”“php树形数据结构的样式我来php树形数据结构的样式了”
array (数组)一般用于复杂数据处理,可以多维数据结构,可以放布尔、整型、浮点、字符、数组等 。
object (对象) 一般用于面向对象,里面包含方法和变量 。
用php调数据库做树状显示数据库设计的时候,通常的做法是用父ID来解决树状结构,也有二叉树等等
idpid category_name
然后,用递归就能实现,也有引用数组的方式
?php
/**
* 此方法由@Tonton 提供
*
* @date 2012-12-12
*/
function genTree5($items) {
foreach ($items as $item)
$items[$item['pid']]['son'][$item['id']] = $items[$item['id']];
return isset($items[0]['son']) ? $items[0]['son'] : array();
}
/**
* 将数据格式化成树形结构
【php树形数据结构的样式 php 树结构】 * @author Xuefen.Tong
* @param array $items
* @return array
*/
function genTree9($items) {
$tree = array(); //格式化好的树
foreach ($items as $item)
if (isset($items[$item['pid']]))
$items[$item['pid']]['son'][] = $items[$item['id']];
else
$tree[] = $items[$item['id']];
return $tree;
}
$items = array(
1 = array('id' = 1, 'pid' = 0, 'name' = '江西省'),
2 = array('id' = 2, 'pid' = 0, 'name' = '黑龙江省'),
3 = array('id' = 3, 'pid' = 1, 'name' = '南昌市'),
4 = array('id' = 4, 'pid' = 2, 'name' = '哈尔滨市'),
5 = array('id' = 5, 'pid' = 2, 'name' = '鸡西市'),
6 = array('id' = 6, 'pid' = 4, 'name' = '香坊区'),
7 = array('id' = 7, 'pid' = 4, 'name' = '南岗区'),
8 = array('id' = 8, 'pid' = 6, 'name' = '和兴路'),
9 = array('id' = 9, 'pid' = 7, 'name' = '西大直街'),
10 = array('id' = 10, 'pid' = 8, 'name' = '东北林业大学'),
11 = array('id' = 11, 'pid' = 9, 'name' = '哈尔滨工业大学'),
12 = array('id' = 12, 'pid' = 8, 'name' = '哈尔滨师范大学'),
13 = array('id' = 13, 'pid' = 1, 'name' = '赣州市'),
14 = array('id' = 14, 'pid' = 13, 'name' = '赣县'),
15 = array('id' = 15, 'pid' = 13, 'name' = '于都县'),
16 = array('id' = 16, 'pid' = 14, 'name' = '茅店镇'),
17 = array('id' = 17, 'pid' = 14, 'name' = '大田乡'),
18 = array('id' = 18, 'pid' = 16, 'name' = '义源村'),
19 = array('id' = 19, 'pid' = 16, 'name' = '上坝村'),
);
echo "pre";
print_r(genTree5($items));
print_r(genTree9($items));
?
PHP MYSQL 的多级分类树结构打开数据库那就不写了 。
前几天刚写了一个 。你看下
/* 表结构
CREATE TABLE `lh_categroy` (
`id` int(10) NOT NULL auto_increment,
`parentid` int(6) NOT NULL,
`name` varchar(255) NOT NULL,
`keyword` varchar(255) NOT NULL COMMENT '关键字',
`des` varchar(255) NOT NULL COMMENT '描述',
PRIMARY KEY(`id`),
UNIQUE KEY `name` (`name`)
) ENGINE=MyISAM AUTO_INCREMENT=44 DEFAULT CHARSET=utf8;
*/
/**
* 获得所有栏目排序后的列表
* @return array
*/
function getAllOrderColumns($id = 0) {
global $columns;
$result = array();
if ($id) $result[$id] = $columns[$id];
foreach ($columns as $column) {
if ($column['parentid'] == $id) {
$column['level'] = 0;
$result[$column['id']] = $column;
getColumns($columns, $column['id'], $result, 1);
}
}
return $result;
}
function getColumns($columns, $cid, $result, $l = 1) {
foreach ($columns as $c) {
if ($c['parentid'] == $cid) {
$c['level'] = $l;
$result[$c['id']] = $c;
getColumns($columns, $c['id'], $result, $l1);
}
}
}
$sql = 'select * from lh_categroy';
$query = mysql_query($sql);
while($row = mysql_fetch_assoc($query)){
$columns[]=$row;
}
$fenlei = '';
$fenlei ='select name="cid" style="width:200px; height:25px;"
option value="https://www.04ip.com/post/0"请选择分类/option';
foreach(getAllOrderColumns() as $v){
$v[name] = $v[level] ? ($v[level]==1 ? 'nbsp;nbsp;|-'.$v[name]:'nbsp;nbsp;nbsp;|-'.$v[name]) : $v[name];
$fenlei .= "option value='https://www.04ip.com/post/$v[id]'$v[name]/option";
}
$fenlei .= '/select';
echo $fenlei;
麻烦各位高手大虾们 给小弟一个 php 简单的树形菜单 代码! 要注释 。。非常感谢?。。。。。?/h2>要看效果,你加Q:573780643
1.jquery支持
script type="text/javascript" src=""/script
script type="text/javascript" src=""/script
script type="text/javascript"
$(document).ready(function() {
$('#tree').lightTreeview({
collapse: true,
line: true,
nodeEvent: true,
unique: true,
style: 'black',
animate: 400
});
});
/script
2.树菜单函数
?
function getCategoryTree($TID, $iTable,$url,$urlPar="1=1") {
if ($TID == 0) {
$treeStr = $treeStr."ul id=\"tree\" class=\"lightTreeview treeview-black\"";
}
$sql = "select * from `$iTable` where TID1 = ".$TID." order by orderid";
$rs = mysql_query($sql);
while ($ary = mysql_fetch_array($rs)) {
$treeStr = $treeStr."li";
$rs2 = mysql_query("select count(*) from `$iTable` where TID1 = ".$ary["id"]);
$Vcount = @mysql_result($rs2, 0);
if ($Vcount != 0) {
$treeStr = $treeStr."div class=\"treeview-folder\"".$ary["title"]."/divul style=\"display:none\"";
$treeStr = $treeStr.getCategoryTree($ary["id"], $iTable,$url,$urlPar);
$treeStr = $treeStr."/ul";
} else {
$treeStr = $treeStr."div class=\"treeview-file\"a href=https://www.04ip.com/"".$url."?T=".$ary["id"]."".$urlPar."\" target=\"pro\"".$ary["title"]."/a/div";
}
$treeStr = $treeStr."/li";
}@mysql_free_result($rs);
if ($TID == 0) {
$treeStr = $treeStr."/ul";
}
return $treeStr;
}
?
3.页面上调用
div
?=getCategoryTree(0,"N_type","edit.php","1=1")?
/div
4.数据结构
id title TID1(上一级ID)
php树形数据结构的样式的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于php 树结构、php树形数据结构的样式的信息别忘了在本站进行查找喔 。
推荐阅读
- java电商项目代码,java电商平台项目
- 重叠拍摄功能是什么,如何拍出重叠效果
- 关于phpcms获取同级栏目的信息
- mysql的服务怎么开 mysql服务怎么开启
- 肯德基餐厅如何设计营销,肯德基营销模式分析
- 鸿蒙os2最新进展,鸿蒙os2介绍
- 凤蝶赌博直播平台,凤蝶赌博直播平台官网
- go语言与c的关系 go语言与golang
- 怎么能取消电脑读取u盘,怎么能取消电脑读取u盘的权限