PHP在重新加载时选择选择选项

时间:2014-04-15 09:56:09

标签: php object select post option

我有这个表格,带有2个selext盒装。包含从数据库加载的网页中的所有菜单项以及所有当前的3种语言。

当我从任何选择框中更改选项时,它应该使用selectbxo中的值重新加载,并且应该根据菜单项和文本进行查询以获取textare中的内容。

这部分工作,内容变化完美,但他不记得所选择的选项,我无法找出原因。

以下是表单,您看到的对象来自收集菜单项和语言项的单独文件。

<form style="border: 1px solid black; " name="form" method="post" action="">
Content selecteren om te wijzigen:
    <table>
        <td>
            <tr>
                <td width="78">Menu item:</td>
                <td><select name="Menu" onchange="this.form.submit()">' . $this->MenuItems->render() . '</select></td>
            </tr><br>

            <tr>
                <td width="78">Taal:</td>
                <td><select name="Language" onchange="this.form.submit()">' . $this->LanguageItems->render() . '</select></td>
            </tr>

            <tr>
                <td>Menu Item:</td>
                <td width="78"><input name="MenuItemTextBox" type="text" id="MenuItemTextBox" value="' . $_POST['Menu'] . '"></td><br>
            </tr>
            <tr>
                <td>content</td>
                <td><TEXTAREA style="" Name="content" id="NewContent" ROWS=10 COLS=50>' . $this->GetContent->render() . '</TEXTAREA></td>   
            </tr>

            <tr>
                <td><input type="submit" name="Submit" value="Wijzigen"></td>
            </tr>

        </td>
    </table>
</form>

这是我从数据库中获取菜单项的代码,并检查帖子是否与其循环的菜单项相同。如果帖子(从选择框的calue创建的帖子)和菜单项相同,则在html选项中粘贴“selected”html元素。

class MenuItems extends content_part{

private $menuLabels = array();
private $menuIDs = array();

 public function __construct(DatabaseHandler $dbh)
{
  if(!isset($_POST['Language'])){
    $_POST['Language'] = 1;
  }

  $SQL = "SELECT menulanguage.Label AS Label, menulanguage.Title AS Title, menulanguage.MenuID AS MenuID FROM Menu JOIN menulanguage ON Menu.MenuID = menulanguage.MenuID WHERE LanguageID = 1;";
  $resultDB = $dbh->executeQuery($SQL);

  if(is_object($resultDB)){
    while($row = $resultDB->fetch(PDO::FETCH_ASSOC)){
      $this->menuLabels[] = $row["Label"];
      $this->menuIDs[] = $row["MenuID"];
    }
  }

  else{echo 'Could not retrieve menu items from database'; }
}

public function render(){
  $Selected = '';
  $result = '';
  $i = 0;

  foreach($this->menuLabels as $menuLabel){
    if (isset($_POST['Menu'])){
      if($menuLabel == $_POST['Menu']){ $Selected = 'selected'; }
      else {}
    }
      $result .= '<option value="' . $this->menuIDs[$i] . '"' . $Selected . '>' . $menuLabel . '</option>';
      $i++;
  }

  return $result;
}}

我见过几个相同的问题,但我真的无法得到答案。

这是填充菜单项

后的选项
<option value="1">Home</option>
<option value="2">Contactus</option>

正如你所看到的,“选定的”html没有填充它,这意味着他无法从表单中找到POST值,为什么会这样?

1 个答案:

答案 0 :(得分:1)

您需要更改:

if($menuLabel == $_POST['Menu']){ $Selected = 'selected'; }

$menuId而不是$menuLabel,因为渲染功能正在向选项输出ID而不是标签的值。

这样的事情应该做你需要的事情:

  foreach($this->menuIDs as $menuID){
    if (isset($_POST['Menu'])){
      if($menuID== $_POST['Menu']){ $Selected = 'selected'; }
      else {}
    }
      $result .= '<option value="' . $this->menuIDs[$i] . '"' . $Selected . '>' . $menuLabel . '</option>';
      $i++;
  }