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

时间:2015-04-07 13:58:35

标签: javascript jquery-plugins jstree

移动节点时我需要重新排列菜单。我认为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)

移动节点时如何获取子数组?

1 个答案:

答案 0 :(得分:0)

好的,我解决了这个问题。我不知道是否可以只使用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查询。