我有一个系统可以重新排列导航项目。
它将新订单存储在一个数组中,然后我使用for循环遍历数组并更新数据库。
<?php
$apageid = array();
$apagename = array();
$apageorder = array();
$q = "SELECT g.id, g.title, n.order FROM tbl_general g INNER JOIN tbl_navigation n ON n.pageid = g.id WHERE n.type = '$_SESSION[parent]' ORDER BY n.order";
$return = $database->query($q);
while($row=mysql_fetch_assoc($return)){
$apageid[] = $row['id'];
$apagename[] = $row['title'];
$apageorder[] = $row['order'];
}
$count = count($apageid);
$bpageid = array();
$bpageorder = array();
?>
<div class="form-holder">
<?php
//run through each page one at a time and update the order of the menu
mysql_data_seek( $return, 0 ); //reset the pointer to do the same query
$i = 0; //the count for saving the new configuration
while($row=mysql_fetch_assoc($return)){
$id = $row['id'];
$title = $row['title'];
$order = $row['order'];
?>
<div class="form-row">
<div class="form-label">
Page Name
</div>
<div class="form-field">
<select class="select-small" name="<?php echo $bpageid[$i]; ?>">
<?php
for($j=0; $j<$count; $j++){
if($apageid[$j] == $id) {
$selected = true;
} else {
$selected = false;
}
?>
<option value="<?php echo $apageid[$j]; ?>" <? echo ($selected == true) ? 'selected="selected"' : ''; ?>><?php echo $apagename[$j]; ?></option>
<?php
}
?>
</select>
<select class="select-small" name="<?php echo $bpageorder[$i]; ?>">
<?php
for($k=0; $k<$count; $k++){
if($apageorder[$k] == $order) {
$selected = true;
} else {
$selected = false;
}
?>
<option value="<?php echo $apageorder[$k]; ?>" <? echo ($selected == true) ? 'selected="selected"' : ''; ?>><?php echo $apageorder[$k]; ?></option>
<?php
}
?>
</select>
</div>
</div>
<?php
$i++;
}
?>
第一块代码是您可以重新排序项目的菜单。
最初它会加载当前选择并允许您更改排序。
function reorderChildren($pageid, $pageorder){
global $database;
$count = count($pageid);
//run through each page one at a time and update the order of the menu
for($i=0; $i<$count; $i++){
//set a few variables
$pid = $pageid[$i];
$porder = $pageorder[$i];
echo "pid = $pid porder = $porder";
$q = "UPDATE tbl_navigation SET order = '$porder' WHERE pageid = '$pid' AND type = '$_SESSION[parent]'";
$database->query($q);
}
return 0;
}
然后信息最终被传递到此处,问题似乎是for循环永远不会被执行。
谁能明白为什么会这样?
这不是使用的命名,我已经检查了它们。
我是否正确地将数据存储在数组中?
我是否可以明确指出,$bpageid
和$bpageorder
是传递信息的数组。
谢谢!
答案 0 :(得分:1)
是一个简单的修复! 问题是选择名称只需要name =“bpageid []”而不是我上面列出的名称。傻!
答案 1 :(得分:0)
你刚刚在第一次循环后在顶部初始化了$bpageid = array();
。没有分配值
之后你使用
<select class="select-small" name="<?php echo $bpageid[$i]; ?>">
但$bpageid[$i]
中没有值,因此此选择框的名称为空。
可能有问题。检查并按要求进行操作。
答案 2 :(得分:0)
你可以尝试从select元素的选项中构造一个json,将它存储到隐藏字段,或者将ajax请求发送到php脚本进行处理,可以从“weight”值1,2,3等订购。 ...用php和循环显示