Reputation: 12472
I was just browsing a forum and someone asked about a PHP file they had found on the web. It has several spots like this in the code:
if ($REMOTE_ADDR == "") $ip = "no ip";
else $ip = getHostByAddr($REMOTE_ADDR);
I have always thought brackets are needed to enclose what you want to do if the condition is true. Is there some other alternative, such as if it is on the same line you don't?
There is also another line like this:
if ($action != ""):
mail("$adminaddress","Visitor Comment from YOUR SITE",
My instinct is to say this wouldn't work, but I also don't know if it is an outdated PHP file and it used to work?
Upvotes: 36
Views: 30501
Reputation: 948
9 years on and I'm surprised no-one's mentioned the ternary operator:
$ip = ($REMOTE_ADDR == "") ? "no ip" : getHostByAddr($REMOTE_ADDR);
Much clearer for assignment IMHO - because it leads out with the variable being assigned to, as for usual variable assignment.
Upvotes: 2
Reputation: 23759
you can do if else statements like this:
<?php
if ($something) {
echo 'one conditional line of code';
echo 'another conditional line of code';
}
if ($something) echo 'one conditional line of code';
if ($something)
echo 'one conditional line of code';
echo 'a NON-conditional line of code'; // this line gets executed regardless of the value of $something
?>
and then you can also write if - else in an alternate syntax:
<?php
if ($something):
echo 'one conditional line of code';
echo 'another conditional line of code';
elseif ($somethingElse):
echo 'one conditional line of code';
echo 'another conditional line of code';
else:
echo 'one conditional line of code';
echo 'another conditional line of code';
endif;
?>
with the alternate syntax you can also fall out of parsing mode like this:
<?php
if ($something):
?>
one conditional line of code<br />
another conditional line of code
<?php
else:
echo "it's value was: $value<br />\n";
?>
another conditional line of code
<?php
endif;
?>
But this gets really messy really fast and I won't recommend it's use (except maybe for template-logic).
and to make it complete:
<?php
$result = $something ? 'something was true' : 'something was false';
echo $result;
?>
equals
<?php
if ($something) {
$result = 'something was true';
} else {
$result = 'something was false';
}
echo $result;
?>
Upvotes: 80
Reputation: 145027
Yes, excluding the braces is allowed, although many times I have heard 2 reasons for not using that syntax:
Also, yes, the colon syntax is valid. The alternatives can be found here: http://php.net/manual/en/control-structures.alternative-syntax.php
Upvotes: 1
Reputation: 39926
brackets are needed to enclose what you want to do if the condition is true
I can't think of any language that requires this
Upvotes: -4
Reputation: 129
In my opinion
if ($REMOTE_ADDR == "") $ip = "no ip"; else $ip = getHostByAddr($REMOTE_ADDR);
is valid, but much harder to read than:
if ($REMOTE_ADDR == "") {
$ip = "no ip";
} else {
$ip = getHostByAddr($REMOTE_ADDR);
}
Upvotes: 2
Reputation: 124307
To go into a little more detail, the reason that the braces are optional is that the syntax looks like:
if(CONDITION) BLOCK
[elseif(CONDITION) BLOCK]
[else BLOCK]
BLOCK can be a single statement:
foo();
or it can be a brace-enclosed group of statements:
{
foo();
bar();
}
Upvotes: 10
Reputation: 124307
Braces (not brackets) are optional in PHP, as in most C-like syntax. Maybe you're thinking of Perl; they're required there, for that form of if syntax.
The colon thing is an alternate control structure form that PHP supports. I hate it, but some people (particularly template system designers, apparently) love it.
Upvotes: 2