通过从节点父级获取所有子级对节点进行排序(获取子级数组)

Sorting nodes with getting all childs from node parent(get array of childs)

本文关键字:节点 获取 排序 数组      更新时间:2023-09-26

移动节点时需要重新排列菜单。我认为js脚本应该使用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]

以及发送到服务器端脚本的数组:

阵列(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查询。