通过从节点 parent 获取所有子节点对节点进行排序(获取子节点数组)
Sorting nodes with getting all childs from node parent(get array of childs)
移动节点时需要重新排列菜单。我认为 js 脚本应该在 parent 中发送 ajax 节点的新顺序。但我不明白如何获得孩子们的阵列。
例如:
列表
- 测试节点[id=1]
- 测试节点2 [id=2]
- 子节点1[id=5]
- 子节点2[id=4]
- 子节点3[id=3]
- 测试节点3[id=6]
当我在子节点 3 之后移动子节点 1 时
更改列表
- 测试节点[id=1]
- 测试节点2 [id=2]
- 子节点2[id=4]
- 子节点3[id=3]
- 子节点1[id=5]
- 测试节点3[id=6]
和发送到 server-side 脚本的数组:
数组(4,3,5)
如何在移动节点时获取子数组?
好的,我解决了那个问题。我不知道仅使用 jstree API 是否可行,但我编写的代码在相同的基础上工作。我用这个PHP,但是我用这种语言编程。
这是 PHP 代码:
$id=intval($_REQUEST['id']);
$parent=intval($_REQUEST['parent']);
$position=intval($_REQUEST['position']);
$r=dbAll('select `id` from `menu` where `parent_id`='.$parent.' order by `order`');
$array=array();
foreach($r as $v)
$array[]=$v['id'];
if(($key = array_search($id, $array)) !== false) {
unset($array[$key]);
}
$insert=array($id);
array_splice( $array, $position, 0, $insert );
$array=array_values($array);
$i=1;
foreach($array as $val){
dbQuery('update `menu` set `order`='.$i.',`parent_id`='.$parent.' where `id`='.$val);
$i++;
}
函数dbAll()用于获取所有匹配的记录,函数dbQuery()用于发送mysqli查询。
移动节点时需要重新排列菜单。我认为 js 脚本应该在 parent 中发送 ajax 节点的新顺序。但我不明白如何获得孩子们的阵列。 例如:
列表
- 测试节点[id=1]
- 测试节点2 [id=2]
- 子节点1[id=5]
- 子节点2[id=4]
- 子节点3[id=3]
- 测试节点3[id=6]
当我在子节点 3 之后移动子节点 1 时
更改列表
- 测试节点[id=1]
- 测试节点2 [id=2]
- 子节点2[id=4]
- 子节点3[id=3]
- 子节点1[id=5]
- 测试节点3[id=6]
和发送到 server-side 脚本的数组:
数组(4,3,5)
如何在移动节点时获取子数组?
好的,我解决了那个问题。我不知道仅使用 jstree API 是否可行,但我编写的代码在相同的基础上工作。我用这个PHP,但是我用这种语言编程。 这是 PHP 代码:
$id=intval($_REQUEST['id']);
$parent=intval($_REQUEST['parent']);
$position=intval($_REQUEST['position']);
$r=dbAll('select `id` from `menu` where `parent_id`='.$parent.' order by `order`');
$array=array();
foreach($r as $v)
$array[]=$v['id'];
if(($key = array_search($id, $array)) !== false) {
unset($array[$key]);
}
$insert=array($id);
array_splice( $array, $position, 0, $insert );
$array=array_values($array);
$i=1;
foreach($array as $val){
dbQuery('update `menu` set `order`='.$i.',`parent_id`='.$parent.' where `id`='.$val);
$i++;
}
函数dbAll()用于获取所有匹配的记录,函数dbQuery()用于发送mysqli查询。