Setting SELECTED value of a drop down list that is populated via a database lookup when posting a form back to itself

Posted on 2014-02-04
Medium Priority
Last Modified: 2014-02-04

I am fairly new to PHP having come from a .NET background and one thing I am missing is the POSTBACK function of the forms and what that offered.

In essence what I am trying to do is have a user select two values from two drop down lists then use these two values and query the database to return the correct value.

If possible I would prefer to just have the one page and then retain the values that are selected on the page in the DDLs when the final value is displayed.

I know it is possible just to have the form action redirect to another page where I could show the values that have been selected but I would much prefer to keep the user not he one page and just keep the selected values int he DDL like I would have done in .NET.

After a search I have found options on setting the selected value but unless I am missing something with the syntax then these don't seem to be working wight eh way I am populating the menu.

I have attached the code I am using for the population of the DDLs below.

$conn = dbconn();

		$query = "SELECT width, mm, inch FROM tbl_width ORDER by mm ASC" or die("Error in the consult.." . mysqli_error($conn));

		$result = $conn->query($query);

		$return_height = "";

		while ($row = mysqli_fetch_array($result)){
			$return_height .= "<option value=\"" . $row['width'] . "\">" . $row['mm'] . " mm ( " . $row['inch'] . " inches )</option>";

		return $return_height;

Open in new window

Many thanks.
Question by:Lee Redhead
  • 2

Accepted Solution

Lee Redhead earned 0 total points
ID: 39833191
I have managed to find a solution to this by the following.

if (isset($sel_width)) {
          $selected = ($row['width'] == $sel_width ? 'selected' : '');
			$return_height .= "<option value=\"" . $row['width'] . "\"" . $selected . ">" . $row['mm'] . " mm ( " . $row['inch'] . " inches )</option>";

Open in new window

This works by running the check outside of the complete line which I think was what I was doing wrong before.

Author Closing Comment

by:Lee Redhead
ID: 39833196
Applying some thought to what was going wrong setting the value as a variable outside of the return worked.

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

3 proven steps to speed up Magento powered sites. The article focus is on optimizing time to first byte (TTFB), full page caching and configuring server for optimal performance.
It’s a season to be thankful, and we’re thankful for users like you who engage on site, solve technology problems, and network with others in the industry. What tech are we most thankful for? Keep reading.
Explain concepts important to validation of email addresses with regular expressions. Applies to most languages/tools that uses regular expressions. Consider email address RFCs: Look at HTML5 form input element (with type=email) regex pattern: T…
The viewer will learn how to look for a specific file type in a local or remote server directory using PHP.

619 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question