creusois | Bonjour à tous,
Voila, je me mets aux templates et je suis un peu perdu.
Je tente de faire un menu, ET aussi la liste des articles. Je m'esplique, j'ai une table SQL avec ces champs
id_article
id_rubrique
titre
article
Je voudrais donc faire un menu avec les titres (donc une boucle), et aussi à coté dans le corps de la page je voudrais afficher les titres et les articles (encore uen boucle). Apres je definirai des ancres pour aller directement depuis le menu vers la position de l'article desiré.
Mais voila, j'ai un peu de mal à mettre deux systemes de template dans la meme page PHP. Si qu'lqu'un avait une idée, merci
Extrait de mon gabarit
Code :
- <div id="menu">
- <div>Menu<br /></div>
- <!-- BEGIN liste_menu -->
- <div>{titre}</div>
- <!-- END liste_menu -->
- </div>
- <div id="corps">
- <!-- BEGIN liste_article -->
- {titre}<br /><br />
- {article}<br />
- <!-- END liste_article -->
- </div>
|
Et voici pour le moment ma page PHP qui ne gere que les titres dans le menu. Je voudrais donc pouvoir remplir le div des articles.
Code :
- <?php
- // On inclue le fichier template.inc
- include "./lib/phplib/php/template.inc";
- //On se connecte à la base de donnée
- include('./config/config.php');
- connexion();
- // On fait la requete SQL
- $sql = 'SELECT id_article, titre FROM '.PREFIXE.'articles WHERE id_rubrique = 1 ORDER BY classement';
- $req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
- //Pour utiliser la commande "new template" il faut indiquer le chemin vers les gabarits (ici = ../gabarits ).
- //- template (string $path)
- $tpl = new template("./gabarits" );
- //Pour utiliser la commande "new template" il faut indiquer le chemin vers les gabarits (ici = ../gabarits ).
- //- template (string $path)
- $tpl->set_file("menu","presentation.html" );
- //Avec la commande "set_block" nous allons créer un bloc qui va correspondre au nom du traitement créé précédemment dans la page HTML. Son utilisation se fait sous cette forme : nom du gabarit, nom du traitement (dans HTML), nom du bloc.
- //- set_block (string $name_gabarit, string $name_HTML,string $name_bloc)
- $tpl->set_block('menu','liste_menu','liste_blocmenu');
- //On fait une boucle qui va faire un tour pour chaque enregistrement
- while($data = mysql_fetch_array($req)) {
- //Grâce à "set_var" nous allons définir les champs notés dans le code HTML.
- //Cette commande s'exécute sous cette forme : nom du champ (dans HTML), valeur (ici récupéré dans la base. Pour chaque différent champ nous exécutons la commande "set_var".
- //set_var(string $name_HTML, string $value)
- $tpl->set_var("titre", stripslashes($data['titre']));
- //Ensuite nous utilisons la commande "parse" qui va nous servir à parcourir la boucle et à remplacer les champs par les valeurs de la db. Sa syntaxe est la suivante : nom du bloc, nom du traitement (dans HTML), true.
- //parse(string $name_bloc, string $name_HTML, true)
- $tpl->parse('liste_blocmenu','liste_menu',true);
- }
- // on ferme la connexion à MySql.
- mysql_close();
- //On finit par l'affichage, avec la commande pparse, qui s'écrit sous la forme :
- //Nom de l'affichage, nom du gabarit.
- //pparse(string $name, string $name_gabarit);
- $tpl->pparse("affichage","menu" );
- ?>
|
Merci beaucoup pour l'aide que vous pourrez m'apporter.
Alexandre |