通过从节点父级获取所有子级对节点进行排序(获取子级数组)
Sorting nodes with getting all childs from node parent(get array of childs)
移动节点时需要重新排列菜单。我认为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查询。
相关文章:
- JavaScript:在XML中搜索节点并从该节点获取数组
- JsTree从未渲染的节点获取html属性
- 如何从jstree中的选定节点获取所有子节点
- 如何从同级节点获取数据
- 始终如一地从 XML 节点获取文本
- 如何使用节点获取发送 cookie
- 使用 jQuery 从 Chrome 中的 XML 节点获取内部 XML
- angular js路由中提供的TemplateURL是't从节点获取响应时加载所需的文件
- 从javascript中的选择性节点获取文本
- 使用递归函数从父节点获取数据
- 如何在没有选择器的情况下从父节点获取子节点
- 从Unirest节点获取请求函数发送响应到Jade视图
- 节点获取接收空正文
- 在Javascript中解析XML时从父节点获取属性
- 使用Javascript或jQuery从子节点获取父跨度标题值
- 使用React和Bacon从节点获取EventStream
- 从元素中的子节点获取值
- 如何从节点获取当前用户
- 有没有一种方法可以让子控制器继承服务呢?从其父节点获取
- 反应;父节点从子节点获取输入数据