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
356 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

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
mimic google as my ip 11 53
hiding/removing php extension - best practice 4 24
using php variable inside javascript 5 13
Intermittent Error on Page Loading 4 15
Generating table dynamically is the most common issue faced by php developers.... So it seems there is a need of an article that explains the basic concept of generating tables dynamically. It just requires a basic knowledge of html and little maths…
This article discusses how to create an extensible mechanism for linked drop downs.
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…
This tutorial will teach you the core code needed to finalize the addition of a watermark to your image. The viewer will use a small PHP class to learn and create a watermark.

910 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

22 Experts available now in Live!

Get 1:1 Help Now