<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.control-structures.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'fr',
  ),
  'this' => 
  array (
    0 => 'control-structures.switch.php',
    1 => 'switch',
    2 => 'switch',
  ),
  'up' => 
  array (
    0 => 'language.control-structures.php',
    1 => 'Les structures de contr&ocirc;le',
  ),
  'prev' => 
  array (
    0 => 'control-structures.continue.php',
    1 => 'continue',
  ),
  'next' => 
  array (
    0 => 'control-structures.match.php',
    1 => 'match',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'fr',
    'path' => 'language/control-structures/switch.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="control-structures.switch" class="sect1">
 <h2 class="title">switch</h2>
 <p class="verinfo">(PHP 4, PHP 5, PHP 7, PHP 8)</p>
 <p class="simpara">
  L&#039;instruction <code class="literal">switch</code> équivaut à une série d&#039;instructions
  <code class="literal">if</code>. En de nombreuses occasions, il est nécessaire de
  comparer la même variable (ou expression) avec un grand nombre de valeurs
  différentes, et d&#039;exécuter différentes parties de code suivant la valeur
  à laquelle elle est égale. C&#039;est exactement à cela que sert l&#039;instruction
  <code class="literal">switch</code>.
 </p>
 <blockquote class="note"><p><strong class="note">Note</strong>: 
  <span class="simpara">
   Il est à noter que contrairement à d&#039;autres langages, la structure
   <a href="control-structures.continue.php" class="link">continue</a> s&#039;applique
   aux structures <code class="literal">switch</code> et se comporte de la même manière
   que <code class="literal">break</code>.
   Si un <code class="literal">switch</code> se trouve dans une boucle, et qu&#039;il
   faut continuer jusqu&#039;à la prochaine itération de la boucle extérieure,
   il est nécessaire d&#039;utiliser <code class="literal">continue 2</code>.
  </span>
 </p></blockquote>
 <blockquote class="note"><p><strong class="note">Note</strong>: 
  <p class="para">
   Il est à noter que switch/case provoque une
   <a href="types.comparisons.php#types.comparisions-loose" class="link">comparaison large</a>.
  </p>
 </p></blockquote>

 <p class="para">
  Dans l&#039;exemple suivant, chaque bloc de code est équivalent.
  L&#039;un utilise une série d&#039;instructions <code class="literal">if</code> et
  <code class="literal">elseif</code>, et l&#039;autre une instruction de type
  <code class="literal">switch</code>. Dans chaque cas, la sortie est la même.
  <div class="example" id="example-1">
   <p><strong>Exemple #1 Instruction <code class="literal">switch</code></strong></p>
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">// Ce switch:<br /><br /></span><span style="color: #007700">switch (</span><span style="color: #0000BB">$i</span><span style="color: #007700">) {<br />    case </span><span style="color: #0000BB">0</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 0"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 1"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 2"</span><span style="color: #007700">;<br />        break;<br />}<br /><br /></span><span style="color: #FF8000">// Équivaut à:<br /><br /></span><span style="color: #007700">if (</span><span style="color: #0000BB">$i </span><span style="color: #007700">== </span><span style="color: #0000BB">0</span><span style="color: #007700">) {<br />    echo </span><span style="color: #DD0000">"i égal 0"</span><span style="color: #007700">;<br />} elseif (</span><span style="color: #0000BB">$i </span><span style="color: #007700">== </span><span style="color: #0000BB">1</span><span style="color: #007700">) {<br />    echo </span><span style="color: #DD0000">"i égal 1"</span><span style="color: #007700">;<br />} elseif (</span><span style="color: #0000BB">$i </span><span style="color: #007700">== </span><span style="color: #0000BB">2</span><span style="color: #007700">) {<br />    echo </span><span style="color: #DD0000">"i égal 2"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 <p class="para">
  Il est important de comprendre que l&#039;instruction
  <code class="literal">switch</code> exécute chacune des
  clauses dans l&#039;ordre. L&#039;instruction <code class="literal">switch</code>
  est exécutée ligne par ligne. Au début,
  aucun code n&#039;est exécuté. Uniquement lorsqu&#039;une instruction 
  <code class="literal">case</code> est trouvée dont 
  l&#039;expression est évaluée à une valeur qui correspond à la valeur de 
  l&#039;expression <code class="literal">switch</code>, PHP exécute alors les instructions correspondantes.
  PHP continue d&#039;exécuter les instructions jusqu&#039;à
  la fin du bloc d&#039;instructions du <code class="literal">switch</code>,
  ou bien dès qu&#039;il trouve l&#039;instruction <code class="literal">break</code>.
  Si l&#039;instruction <code class="literal">break</code> n&#039;est pas utilisée
  à la fin de l&#039;instruction
  <code class="literal">case</code>, PHP continuera à exécuter
  toutes les instructions qui suivent. Par exemple :
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">switch (</span><span style="color: #0000BB">$i</span><span style="color: #007700">) {<br />    case </span><span style="color: #0000BB">0</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 0"</span><span style="color: #007700">;<br />    case </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 1"</span><span style="color: #007700">;<br />    case </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 2"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 <p class="simpara">
  Dans cet exemple, si <var class="varname">$i</var> est égal à 0, PHP va
  exécuter quand même toutes les instructions qui
  suivent ! Si <var class="varname">$i</var> est égal à 1, PHP exécutera
  les deux dernières instructions. Et seulement si <var class="varname">$i</var> est
  égal à 2, le résultat
  escompté sera obtenu, c&#039;est-à-dire, l&#039;affichage de
  &quot;i égal 2&quot;. Donc, l&#039;important est de ne pas oublier
  l&#039;instruction <code class="literal">break</code> (même s&#039;il est
  possible de l&#039;omettre dans certaines circonstances).
 </p>
 <p class="simpara">
  Dans une commande <code class="literal">switch</code>, une condition n&#039;est
  évaluée qu&#039;une fois, et le résultat est
  comparé à chaque <code class="literal">case</code>.
  Dans une structure <code class="literal">elseif</code>, les conditions sont
  évaluées à chaque comparaison. Si la
  condition est plus compliquée qu&#039;une simple
  comparaison, ou bien fait partie d&#039;une boucle,
  <code class="literal">switch</code> sera plus rapide.
 </p>
 <p class="para">
  La liste de commandes d&#039;un <code class="literal">case</code> peut
  être vide, auquel cas PHP utilisera la liste de
  commandes du cas suivant.
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">switch (</span><span style="color: #0000BB">$i</span><span style="color: #007700">) {<br />    case </span><span style="color: #0000BB">0</span><span style="color: #007700">:<br />    case </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />    case </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i est plus petit que 3 mais n'est pas négatif"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">3</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 3"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 <p class="para">
  Un cas spécial est <code class="literal">default</code>. Ce cas est utilisé lorsque tous
  les autres cas ont échoué. Par exemple :
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">switch (</span><span style="color: #0000BB">$i</span><span style="color: #007700">) {<br />    case </span><span style="color: #0000BB">0</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 0"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 1"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 2"</span><span style="color: #007700">;<br />        break;<br />    default:<br />       echo </span><span style="color: #DD0000">"i n'est ni égal à 2, ni à 1, ni à 0."</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
  <blockquote class="note"><p><strong class="note">Note</strong>: 
   <span class="simpara">
    Plusieurs cas default lèveront une erreur de niveau
    <strong><code><a href="errorfunc.constants.php#constant.e-compile-error">E_COMPILE_ERROR</a></code></strong>.
   </span>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Note</strong>: 
   <span class="simpara">
    Techniquement, le cas <code class="literal">default</code> peut être placé
    à n&#039;importe quelle position. Il ne sera utilisé que si aucun autre cas ne correspond.
    Cependant, par convention, il est préférable de le placer à la fin.
   </span>
  </p></blockquote>
 </p>
 <p class="para">
  Si aucun <code class="literal">case</code> ne correspond, et qu&#039;il n&#039;y a pas de <code class="literal">default</code>, alors aucun code ne sera exécuté, tout comme si aucune instruction <code class="literal">if</code> n&#039;était vraie.
 </p>
<p class="para">
    Une valeur de <code class="literal">case</code> peut être donnée sous forme d&#039;expression. Cependant, cette expression sera
  évaluée seule, puis comparée de manière approximative à la valeur du <code class="literal">switch</code>. Cela signifie
  qu&#039;elle ne peut pas être utilisée pour des évaluations complexes de la valeur du <code class="literal">switch</code>. Par exemple :
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$target </span><span style="color: #007700">= </span><span style="color: #0000BB">1</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$start </span><span style="color: #007700">= </span><span style="color: #0000BB">3</span><span style="color: #007700">;<br /><br />switch (</span><span style="color: #0000BB">$target</span><span style="color: #007700">) {<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"A"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"B"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">3</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"C"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">4</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"D"</span><span style="color: #007700">;<br />        break;<br />}<br /><br /></span><span style="color: #FF8000">// Affiche "B"<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 <p class="para">
  Pour des comparaisons plus complexes, la valeur <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> peut être utilisée comme valeur de <code class="literal">switch</code>.
  Ou, alternativement, des blocs <code class="literal">if</code>-<code class="literal">else</code> au lieu de <code class="literal">switch</code>.
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$offset </span><span style="color: #007700">= </span><span style="color: #0000BB">1</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">$start </span><span style="color: #007700">= </span><span style="color: #0000BB">3</span><span style="color: #007700">;<br /><br />switch (</span><span style="color: #0000BB">true</span><span style="color: #007700">) {<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">$offset </span><span style="color: #007700">=== </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"A"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">$offset </span><span style="color: #007700">=== </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"B"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">$offset </span><span style="color: #007700">=== </span><span style="color: #0000BB">3</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"C"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">$start </span><span style="color: #007700">- </span><span style="color: #0000BB">$offset </span><span style="color: #007700">=== </span><span style="color: #0000BB">4</span><span style="color: #007700">:<br />        print </span><span style="color: #DD0000">"D"</span><span style="color: #007700">;<br />        break;<br />}<br /><br /></span><span style="color: #FF8000">// Affiche "B"<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 <p class="para">
  La syntaxe alternative pour cette structure de contrôle est
  la suivante : (pour plus d&#039;informations, voir
  <a href="control-structures.alternative-syntax.php" class="link">syntaxes
  alternatives</a>).
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">switch (</span><span style="color: #0000BB">$i</span><span style="color: #007700">):<br />    case </span><span style="color: #0000BB">0</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 0"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">1</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 1"</span><span style="color: #007700">;<br />        break;<br />    case </span><span style="color: #0000BB">2</span><span style="color: #007700">:<br />        echo </span><span style="color: #DD0000">"i égal 2"</span><span style="color: #007700">;<br />        break;<br />    default:<br />        echo </span><span style="color: #DD0000">"i n'est ni égal à 2, ni à 1, ni à 0"</span><span style="color: #007700">;<br />endswitch;<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 <p class="para">
  Il est possible d&#039;utiliser un point-virgule plutôt que deux points après
  un case, comme ceci :
  <div class="informalexample">
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">switch(</span><span style="color: #0000BB">$beer</span><span style="color: #007700">)<br />{<br />    case </span><span style="color: #DD0000">'leffe'</span><span style="color: #007700">;<br />    case </span><span style="color: #DD0000">'grimbergen'</span><span style="color: #007700">;<br />    case </span><span style="color: #DD0000">'guinness'</span><span style="color: #007700">;<br />    case </span><span style="color: #DD0000">'jupiler'</span><span style="color: #007700">;<br />        echo </span><span style="color: #DD0000">'Bon choix'</span><span style="color: #007700">;<br />        break;<br />    default;<br />        echo </span><span style="color: #DD0000">'Merci de faire un nouveau choix...'</span><span style="color: #007700">;<br />        break;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
 </p>
 
  <div class="sect2">
  <h3 class="title">Voir aussi</h3>
  <p class="para">
   <ul class="simplelist">
    <li><a href="control-structures.match.php" class="link">match</a></li>
   </ul>
  </p>
 </div>
</div><?php manual_footer($setup); ?>