If you are a beginner to PHP, learning how to use control structures is a must. In this article Joel will assist you guys by providing coherent examples.
Control structures are beneficial when coding in PHP. Many tasks can be accomplished with a small amount of coding but basic understanding on how to use them will solve many coding problems.
What are Control Structures?
Control Structures are often referred to as Conditionals, Branching or their familiar name, "Loops".
Loops are great for retrieving information from databases, constructing tables and building dynamic pulldown menus.
Here is a list of the different types of conditionals in PHP:
- if/else
- if/elseif/else
- do/while
- for
- while
- foreach
The "if/else" conditional is the most commonly used statement in PHP coding.
View the following code:
<?php
$number ='5';
if($number =='3')
{
echo "The number is equal to 3";
}
else
{
echo "The number is equal to $number";
}
?>
Explanation of the code:
- The $number variable sets it's value to 5.
- If the $number variable is equal to 3 and becomes true the echo language construct displays the number is equal to 3. This statement is FALSE.
- Since the $number variable is really a value of 5 then it continues until it reaches the end of the conditional and displays The number is equal to 5. This statement is TRUE.
Extending the conditional with the "if/elseif/else" statement would allow more options.
View the following code:
<?php
$number = 7;
if($number == '5')
{
echo "The number is not equal to 7";
}
elseif($number <> '9')
{
echo "The number is not equal to 9";
}
else
{
echo "The number is equal to $number";
}
?>
Explanation of the code:
- The $number variable sets it's value to 7.
- If the $number variable is equal to 5, the echo language construct displays that its not equal to 7. This statement is FALSE.
- If the $number variable is not equal to 9, the echo language construct displays it is not equal to 9. This statement is TRUE.
- The second conditional is the true statement of the script and the script terminates.
Lets turn to "Loops" starting with the "for" conditional. The basic structure will continue looping until it resolves to FALSE.
Here is an example of the "for" conditional that builds a pulldown menu with the years specified by the variable $x and the operand on the right.
View the following code:
<?php
echo '<FORM ACTION="results.php" METHOD=post>';
echo '<SELECT name=year>';
echo"<OPTION VALUE=\"/\">Pick a year</OPTION>";
for($x = 1950; $x <= 2003; $x++)
{
echo "<OPTION VALUE=$x>$x</OPTION>";
}
echo "</SELECT></FORM>";
?>
Explanation of the code:
- A pulldown form is created complete with method and action.
- The variable, $year is specified but the values are not set.
- The top position on the pulldown menu is created using a forward slash to equal null and displays the "Pick a year" portion of the menu.
- The "for" loop counts from the first value, 1950 and loops until it reaches the value or year, 2003.
- The curly brace helps exit the loop and the closing tags finish the form.
The "while" conditional helps loop through the tables of a database to retrieve the information and display onto a page.
Here is an example of the "while" conditional creating a dynamic pulldown menu from a database:
<?php
include('config.php');
dbconnect();
$sql = SELECT DISTINCT(column_name) FROM $table_name;
$result = @mysql_query($sql);
echo "<FORM method=POST action=results.php>";
echo "<SELECT NAME=column_name>";
while($row = @mysql_fetch_array($result))
{
echo "<OPTION VALUE=\"$row[0]\">$row[0]</OPTION>";
}
echo "<INPUT TYPE=submit name=submit VALUE=\"Get Results\"></SELECT></FORM>";
?>
Explanation of the code:
- An include file holds functions and database related information used by the script. The script connects to the database and selects the table.
- The query selects the distinct column and narrows it down to the specified rows of the table.
- The query values are set and the form is created using the column name derived from the SQL commands.
- The "while" loop creates the pulldown menu and the row values are set.
Creating a pulldown menu that contains the months of the year would be bothersome using HTML. Using an array to hold the information and the "foreach()" statement helps speed things up in the long run.
View the following code:
<?php
$month = array("January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "Novemeber", "December");
echo "<FORM METHOD=POST ACTION = results.php>";
echo "<SELECT NAME=column_name >";
echo"<OPTION VALUE=\"/\">Pick a Month</OPTION>";
foreach($month as $MON)
{
echo "<OPTION VALUE=\"$MON\">$MON</OPTION>";
}
echo "</SELECT></FORM>";
?>
Explanation of the code:
- An array is created with the names of all 12 months.
- The form is constructed with the method and action.
- The top position on the pulldown menu, labeled "Pick a Month" is created using a forward slash and it's value is set to null.
- The foreach construct extracts the values of the $month variable and produces the pulldown menu with each month's name.
- The curly brace helps exit the loop and the closing tags finish the form.
I hope this gives you an understanding of Control Structures and how to use conditionals to your advantage.
Happy coding and remember, "Let the code do the work".
Copyright 2003 - Written by Joel Philip - http://www.phpcollege.com
| DISCLAIMER: The content provided in this article is not warranted or guaranteed by Developer Shed, Inc. The content provided is intended for entertainment and/or educational purposes in order to introduce to the reader key ideas, concepts, and/or product reviews. As such it is incumbent upon the reader to employ real-world tactics for security and implementation of best practices. We are not liable for any negative consequences that may result from implementing any information covered in our articles or tutorials. If this is a hardware review, it is not recommended to open and/or modify your hardware. |
More PHP Articles
More By Joel Philip
developerWorks - FREE Tools! |
Visit IBM developerWorks to download a free trial version of Lotus Quickr 8.0, which enables collaboration by transforming the way everyday business content such as documents, rich media, photos, and video can be shared. Lotus Quickr makes it faster and easier to share content of all types (not just documents) within virtual teams. It is designed to make it easier to collaborate across organizational boundaries, while continuing to work within the context of familiar desktop applications. FREE! Go There Now!
|
|
|
|
Download a free trial version of IBM DB2 9.5 for Linux, UNIX, and Windows. DB2 9 is the result of a five-year development project that transformed traditional (static) database technology into an interactive data server that merges the high performance and ease of use of DB2 with the self-describing benefits of XML. FREE! Go There Now!
|
|
|
|
Visit IBM developerWorks to download IBM DB2 Express-C 9.5, a no-charge version of DB2 Express 9 database server. DB2 Express-C offers the same core data server base features as other DB2 Express editions and provides a solid base to build and deploy applications developed using C/C++, Java, .NET, PHP, and other programming languages. FREE! Go There Now!
|
|
|
|
Download a free trial version of IBM Rational Software Analyzer Developer Edition V7.0 to identify bug defects earlier in the software development cycle. Rational Software Analyzer is an extensible software development solution that reduces the expense of bug-fixes by enabling static analysis code reviews and bug identification very early in the development cycle. FREE! Go There Now!
|
|
|
|
Manage, govern, and share services across your organization by using WebSphere Service Registry and Repository. Follow the hands-on exercises to learn how to navigate the Web interface to publish, find, reuse, and update services. FREE! Go There Now!
|
|
|
|
Analysts, architects, and developers who have existing COBOL or PL/I skills and want to extend those skills to deploy new workloads on the mainframe can use the IBM Enterprise Modernization Sandbox for System z to find hands-on walkthroughs of common real world scenarios. The scenarios provide examples of how to rapidly design, create, assemble, test, and deploy high-quality Web, Web services, portal, and SOA applications for IBM CICS, IBM IMS, and IBM WebSphere Application Server. FREE! Go There Now!
|
|
|
|
Rational Modeling Extension for Microsoft .NET enhances usability for code generation supporting a more intelligent refactoring. The latest enhancements enable organizations with Java and .NET systems and software development maintain architectural integrity across heterogeneous platforms. FREE! Go There Now!
|
|
|
|
Attend this launch webcast with Scott Hebner, Vice President of IBM Rational Marketing and Strategy, where he will overview Rational’s new offerings and programs to help customers accelerate software innovation on System z. He will discuss how these solutions help organizations extend their core business processes toward modern architectures such as SOA and web technologies to deliver business improvements that stand the test of time. FREE! Go There Now!
|
|
|
|
User communities play an important role in communication and collaboration around products, solutions and other areas of special interest to members. Successful communities are able to provide the right mix of content and services to deliver a value proposition that resonates with each audience. Join Tom Inman, VP of Marketing for Information and Platform Solutions as he introduces the new LeverageINFORMATION community. During this webcast, learn about the value provided by the community and how customers and partners derive value from the community in addressing their own technical and business challenges. FREE! Go There Now!
|
|
|
|
Explore how Rational and WebSphere software enable enterprise documentation in SOA environments. Specifically, a new integration between IBM WebSphere® Business Modeler and IBM Rational® Method Composer software can help technical writers more easily keep enterprise operations manuals in sync with changes that are made to business processes, resulting in more accurate and timely documentation that benefits the entire enterprise. FREE! Go There Now!
|
|
|
|
All FREE IBM® developerWorks Tools! |