简体   繁体   English

重新加载同一页面时使用php设置选择选项

[英]Set select option using php when reloading the same page

I have a php select populated and given a matching value by using php to loop through the results of a sql query. 我有一个php选择填充,并通过使用php循环遍历sql查询的结果给出了一个匹配的值。

$result = mysqli_query($con, "select * from course")

echo "<form action='' method='post'>";
echo "<select name='CourseSelect'>";
echo "<option value='0'> - Select Course - </option>";
while($row = mysqli_fetch_array($result))
{
 echo "<option value='" . $row['Title'] ." '>" . $row['Title'] . "</option>";
}

echo "</select>";
echo "<input name='SubmitCourse' type='submit'>";
echo "</form>";

That gives me a drop down list populated with all course titles, upon submission I can access the selected value using $_POST['CourseSelect']; 这给了我一个下拉列表,其中包含所有课程标题,提交后,我可以使用$_POST['CourseSelect'];访问选定的值$_POST['CourseSelect'];

However the drop down (select) resets itself to the default value when the page reloads. 但是,当页面重新加载时,下拉菜单(选择)会将其自身重置为默认值。

How can I keep that option selected using php? 如何使用php保持选择该选项?

I know that I can use the selected keyword inside of an a select option to make that option the default selected option. 我知道我可以在一个select选项中使用selected关键字,以使该选项成为默认的selected选项。

for example the second option would be selected when loading the page: 例如,加载页面时将选择第二个选项:

<select>
<option>One</option>
<option selected>Two</option>
<option>Three</option>
</select>

You can make it simple as 您可以简化为

while($row = mysqli_fetch_array($result))
{
 $select = '';
 if( isset($_POST['CourseSelect']) && $_POST['CourseSelect'] == $row['Title'] ) $select = 'SELECTED';
 echo "<option value='".$row['Title']."' ".$select.">" . $row['Title'] . "</option>";
}
you can use like below..

$result = mysqli_query($con, "select * from course");
$selected = "";
echo "<form action='' method='post'>";
echo "<select name='CourseSelect'>";
echo "<option value='0'> - Select Course - </option>";
while($row = mysqli_fetch_array($result))
{
 $selected = $row['Title'] == $_REQUEST['CourseSelect'] ? "Selected" : "";
 echo "<option value='" . $row['Title'] ." '  $selected>" . $row['Title'] . "</option>";
}

echo "</select>";
echo "<input name='SubmitCourse' type='submit'>";
echo "</form>";

try this: 尝试这个:

echo "<option value='0'> - Select Course - </option>";
while($row = mysqli_fetch_array($result))
{
  $selected = $_POST['CourseSelect'] == $row['Title'] ? 'selected' : '';
  echo "<option value='{$row['Title']}' {$selected}>{$row['Title']}</option>"; 
}

you can do like this 你可以这样

echo "<form action='' method='post'>";
echo "<select name='CourseSelect'>";

if( isset($_POST['CourseSelect']) &&  $_POST['CourseSelect'] != "0")
{
    echo "<option >".$_POST['CourseSelect']."</option>";
}
else
{
     echo "<option value='0'> - Select Course - </option>";
}
while($row = mysqli_fetch_array($result))
{
 if( isset($_POST['CourseSelect']) && $_POST['CourseSelect'] != $row['Title'])
 echo "<option value='" . $row['Title'] ." '>" . $row['Title'] . "</option>";
}
echo "</select>";
echo "<input name='SubmitCourse' type='submit'>";
echo "</form>";

PHP Function PHP功能

# select box
/*
Example: 
Parameter 1:      
         $options[1] = 'Course 1'; 
         $options[2] = 'Course 2'; 
         $options[3] = 'Course 3';
Parameter 2:
         $selectedOption = 2; The dropdown need to be selected
*/
function buildOptions($options, $selectedOption)
{
   foreach ($options as $value => $text)
   {
       if ($value == $selectedOption)
       {
        $Return .='<option value="'.$value.'" selected="selected">'.stripslashes($text).'</option>';
       }
       else
       {
        $Return .='<option value="'.$value.'">'.stripslashes($text).'</option>';
       }
   }

   return $Return;

} }

Function Call 函数调用

$result = mysqli_query($con, "select * from course");

while ($row = mysqli_fetch_array($result))
{
 $UniqueId = $row['Title'];
 $Value    = $row['Title'];
 $optionsArray[$UniqueId] = $Value; // Store the values into an array
}

$CourseSelect = isset($_POST['CourseSelect']) ? $_POST['CourseSelect'] : '0';


echo "<form action='' method='post'>";
echo "<select name='CourseSelect'>";
echo "<option value='0'> - Select Course - </option>";
echo  buildOptions($optionsArray, $CourseSelect);
echo "</select>";
echo "<input name='SubmitCourse' type='submit'>";
echo "</form>";

Notes You can use buildOptions() for all of your projects to display select box. 注意您可以对所有项目使用buildOptions()来显示选择框。 I have been using this for years. 我已经使用了多年了。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM