2010-05-22 6 views
-2

je le code HTML suivant:Troubles affichant un tableau associatif avec PHP et HTML

<div id="newsTicker"> 
    <span class="icon news"></span> 
     <ul> 
      [repeating structure] 
      <li> 
       <ul> 
        <li><a href="#">News 1</a></li> 
        <li><a href="#">News 2</a></li> 
        <li><a href="#">News 3</a></li> 
       </ul> 
      </li>    
      [/repeating structure]   
     </ul> 
</div><!--/#newsTicker--> 

J'ai aussi un tableau PHP:

Array 
(
    [0] => Array 
     (
      [id] => 5 
      [title] => Concert Aria Urbana 
      [link] => http://www.searadeseara.ro/detalii-eveniment/aria-urbana-9.html 
      [date] => 2010-05-22 14:59:20 
     ) 

    [1] => Array 
     (
      [id] => 4 
      [title] => Poze Tequila Party 
      [link] => http://www.searadeseara.ro/detalii-galerie/tequila-party-3/ 
      [date] => 2010-05-22 14:58:56 
     ) 

    [2] => Array 
     (
      [id] => 3 
      [title] => Psyche este utilizatorul saptamanii 
      [link] => http://www.searadeseara.ro/profil/1-Psyche.html 
      [date] => 2010-05-22 14:48:03 
     ) 

    [3] => Array 
     (
      [id] => 2 
      [title] => Galerie foto Summer Party 
      [link] => http://www.searadeseara.ro/detalii-galerie/summer-party-8/ 
      [date] => 2010-05-22 14:25:13 
     ) 

    [4] => Array 
     (
      [id] => 1 
      [title] => Concert Massive Attack 
      [link] => http://www.searadeseara.ro/detalii-eveniment/massive-attack-revin-la-bucuresti-13.html 
      [date] => 2010-05-22 14:24:37 
     ) 

) 

Je voudrais savoir comment je peux répéter code à l'intérieur [structure extensible] et affiche 3 nouvelles différentes pour chaque structure répétitive.

La sortie doit ressembler à ceci:

<div id="newsTicker"> 
    <span class="icon news"></span> 
     <ul>    
      <li> 
       <ul> 
        <li><a href="#">Concert Aria Urbana</a></li> 
        <li><a href="#">Poze Tequila Party</a></li> 
        <li><a href="#">Psyche este utilizatorul saptamanii</a></li> 
       </ul> 
      </li>    
      <li> 
       <ul> 
        <li><a href="#">Galerie foto Summer Party</a></li> 
        <li><a href="#">Concert Massive Attack</a></li>      
       </ul> 
      </li> 

     </ul> 
</div><!--/#newsTicker--> 

Merci.

+0

pourquoi ne pas vous poster ici un code réel? –

+0

Parce que je ne sais pas écrire le vrai code (PHP). C'est pourquoi je demande ici. – Psyche

+0

En effet - à quoi sert la structure répétitive? Quelle est la différence entre "News 1" la première fois et la deuxième fois? Pourriez-vous imprimer la structure que vous voulez afficher et coller dans la question? – Amadan

Répondre

1

diviser les données dans un tableau de tableaux de 3 éléments:

$news = // Your big array 
define('NUM_NEWS_PER_GROUP', 3); 

$newsGroups = array(); 
for ($i = 0; $i < count($news); $i += NUM_NEWS_PER_GROUP) { 
    $newsGroups[] = array_slice($news, $i, NUM_NEWS_PER_GROUP); 
} 

Ensuite, pour afficher:

<ul>    
<?php foreach ($newsGroups as $newsGroup) : ?> 
    <li> 
     <ul> 
     <?php foreach ($newsGroup as $item) : ?> 
      <li><a href="#"><?php echo $item['title'] ?></a></li> 
     <?php endforeach; ?> 
     </ul> 
    </li> 
<?php endforeach; ?>   
</ul> 

de cette façon, lorsque vous changez d'avis et souhaitez 4 nouvelles par groupe, vous changez la valeur constante juste.

0

Vos questions n'ont pas vraiment de sens; mais pour obtenir une liste des éléments d'information dans votre tableau, vous voulez faire quelque chose comme ça

<div id="newsTicker"> 
    <span class="icon news"></span> 
     <ul> 
      <li> 
       <ul> 
     <?php 
     foreach ($newsArray as $newsItem){ 
      echo '<li><a href="'.$newsItem['link'].'">'.$newsItem['title'].'</a></li>'; 
     } 
     ?> </ul> 
     </li> 
    </ul> 
</div> 
+0

J'ai mis à jour le poste avec la sortie désirée. – Psyche

0

Vous n'avez pas répondu à ma question sur l'absence de la deuxième dimension dans vos données - je vous pensé que peut-être souhaitant découper la liste à plat en morceaux de trois (un indice du commentaire "news ticker" à la fin était légèrement utile). Si c'est le cas, cela devrait fonctionner aussi longtemps que les articles $ est un tableau réel (a des indices consécutifs à partir de 0):

<div id="newsTicker"> 
    <span class="icon news"></span> 
     <ul> 
<?php 
    $outer = 0; 
    $count = count($items); 
    while ($outer < count($items)) { 
?> 
      <li> 
       <ul> 
<?php 
    for ($inner = 0; $inner < 3 && $outer < $count; $inner++, $outer++) { 
     echo '<li><a href="' 
      . $items[$outer]['link'] . '">' 
      . $items[$outer]['title'] . "</a></li>\n"; 
    } 
?> 
       </ul> 
      </li> 
<?php 
    } 
?> 
     </ul> 
</div><!--/#newsTicker--> 
+0

Heh, désolé, je me suis précipité avec des conclusions :) Ouais, c'est la sortie que je pensais que vous vouliez. J'espère que cela t'aides. – Amadan

+0

Merci l'homme. Je vais l'essayer maintenant. – Psyche

0

En supposant que vous avoir un tableau avec les touches numériques, essayez ceci:

<ul> 
<?php 
foreach ($arr as $key => $item) { 
    // start new list if $key is divisible by 3 
    if ($key % 3 == 0) { 
     echo '<li><ul>'; 
    } 

    echo '<li><a href="…">…</a></li>'; 

    // end list if the next $key will start a new list 
    if (($key + 1) % 3 == 0) { 
     echo '</ul></li>'; 
    } 
} 

// end list if the last iteration did not do it 
if (($key + 1) % 3 != 0) { 
     echo '</ul></li>'; 
} 
?> 
</ul> 
Questions connexes