Solved

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
2
355 Views
Last Modified: 2014-02-04
Hello,

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.
0
Comment
Question by:Lee Redhead
  • 2
2 Comments
 

Accepted Solution

by:
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.
0
 

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.
0

Featured Post

What Security Threats Are You Missing?

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

Join & Write a Comment

Introduction Many web sites contain image galleries; a common design for these galleries includes a page with a collection of thumbnail images.  You can click on each of the thumbnail images to see the larger version of the image.  This is easily i…
These days socially coordinated efforts have turned into a critical requirement for enterprises.
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
The viewer will learn how to create a basic form using some HTML5 and PHP for later processing. Set up your basic HTML file. Open your form tag and set the method and action attributes.: (CODE) Set up your first few inputs one for the name and …

707 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

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now