There is no good way to interpret the dangling else. One must pick a way and apply rules based on that.
Since there is no endif before an else, there is no easy way for PHP to know what you mean.
elseif/else if
(PHP 4, PHP 5)
elseif, comme son nom l'indique, est une combinaison
de if et de else. Comme l'expression
else, il permet d'exécuter une instruction
après un if dans le cas où le "premier"
if est évalué comme FALSE. Mais,
à la différence de l'expression else,
il n'exécutera l'instruction que si l'expression conditionnelle
elseif est évaluée comme
TRUE. L'exemple suivant affichera
a est plus grand que b,
a est égal à b ou
a est plus petit que b :
<?php
if ($a > $b) {
echo "a est plus grand que b";
} elseif ($a == $b) {
echo "a est égal à b";
} else {
echo "a est plus petit que b";
}
?>
Vous pouvez avoir plusieurs elseif qui se suivent
les uns après les autres, après un if initial.
Le premier elseif qui sera évalué
à TRUE sera exécuté. En PHP, vous
pouvez aussi écrire "else if" en deux mots et
son comportement sera identique à la version en un seul mot.
La sémantique des deux expressions est légèrement
différente, mais au bout du compte, le résultat sera
exactement le même.
L'expression elseif est exécutée
seulement si le if précédent et tout
autre elseif précédent sont
évalués comme FALSE, et que
votre elseif est évalué à
TRUE.
Note: A noter que elseif et else if sont traités de la même façon seulement quand des accolades sont utilisées, comme dans l'exemple ci-dessus. Quand vous utilisez ":" pour définir votre condition if/elseif, vous ne devez pas séparer else if en deux mots, sans quoi PHP soulèvera une erreur d'interprétation.
<?php
/* Mauvaise méthode : */
if($a > $b):
echo $a." est plus grand que ".$b;
else if($a == $b): // ne compilera pas
echo "La ligne ci-dessus provoque une erreur d'interprétation";
endif;
/* Bonne méthode : */
if($a > $b):
echo $a." est plus grand que ".$b;
elseif($a == $b): // Les deux mots sont collés
echo $a." égal ".$b;
else:
echo $a." est plus grand ou égal à ".$b;
endif;
?>
The parser doesn't handle mixing alternative if syntaxes as reasonably as possible.
The following is illegal (as it should be):
<?
if($a):
echo $a;
else {
echo $c;
}
?>
This is also illegal (as it should be):
<?
if($a) {
echo $a;
}
else:
echo $c;
endif;
?>
But since the two alternative if syntaxes are not interchangeable, it's reasonable to expect that the parser wouldn't try matching else statements using one style to if statement using the alternative style. In other words, one would expect that this would work:
<?
if($a):
echo $a;
if($b) {
echo $b;
}
else:
echo $c;
endif;
?>
Instead of concluding that the else statement was intended to match the if($b) statement (and erroring out), the parser could match the else statement to the if($a) statement, which shares its syntax.
While it's understandable that the PHP developers don't consider this a bug, or don't consider it a bug worth their time, jsimlo was right to point out that mixing alternative if syntaxes might lead to unexpected results.
Note that } elseif() { is somewhat faster than } else if() {
===================================
Test (100,000,000 runs):
<?php
$start = microtime(true);
for($i = 0; $i < 100000000; $i++) {
if(2 === 0) {} else if(2 === 1) {} else {}
}
$end = microtime(true);
echo "1: ".($end - $start)."\n";
unset($start, $end);
$start = microtime(true);
for($i = 0; $i < 100000000; $i++) {
if(2 === 0) {} elseif(2 === 1) {} else {}
}
$end = microtime(true);
echo "2: ".($end - $start);
?>
===================================
Result (depending on hardware configuration):
1: 20.026723146439
2: 20.20437502861
