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