首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >排序节点,从节点父节点获取所有子节点(获取子节点数组)

排序节点,从节点父节点获取所有子节点(获取子节点数组)
EN

Stack Overflow用户
提问于 2015-04-07 13:58:34
回答 1查看 178关注 0票数 0

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

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

Array(4,3,5)

当我移动节点时,如何得到这个数组的子类?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-08 14:01:41

好吧,我解决了这个问题。我不知道只使用jstree API是否可能,但我编写的代码在相同的基础上工作。我使用这个PHP,但在这种语言中我会编程。这是PHP代码:

代码语言:javascript
复制
$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查询。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29493401

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档