Files
smarty/docs/fr/designers/language-builtin-functions/language-function-include.xml

190 lines
5.2 KiB
XML
Raw Normal View History

2004-04-13 15:43:47 +00:00
<?xml version="1.0" encoding="iso-8859-1"?>
<!-- $Revision$ -->
2005-12-01 20:28:15 +00:00
<!-- EN-Revision: 1.9 Maintainer: gerald Status: ready -->
2004-05-23 15:44:59 +00:00
<sect1 id="language.function.include">
2005-05-26 18:10:32 +00:00
<title>{include}</title>
2005-12-01 20:28:15 +00:00
<para>
Les balises "{include}" sont utilis<69>es pour inclure des templates <20>
l'int<6E>rieur d'autres templates. Toutes les variables disponibles
dans le template r<>alisant l'inclusion sont disponibles dans le
template inclus. La balise {include} doit disposer de l'attribut
"file", qui contient le chemin de la ressource template.
</para>
<para>
Vous pouvez sp<73>cifier un attribut optionnel <emphasis>'assign'</emphasis>
qui d<>finit une variable de template dans laquelle la sortie de
{include} sera stock<63>e plut<75>t qu'affich<63>e.
</para>
2004-05-23 15:44:59 +00:00
<informaltable frame="all">
<tgroup cols="5">
<colspec colname="param" align="center" />
<colspec colname="type" align="center" />
<colspec colname="required" align="center" />
<colspec colname="default" align="center" />
<colspec colname="desc" />
<thead>
<row>
<entry>Nom attribut</entry>
<entry>Type</entry>
<entry>Requis</entry>
<entry>Defaut</entry>
<entry>Description</entry>
</row>
</thead>
<tbody>
<row>
<entry>file</entry>
<entry>cha<EFBFBD>ne de caract<63>res</entry>
<entry>Oui</entry>
<entry><emphasis>n/a</emphasis></entry>
<entry>Le nom du template <20> inclure</entry>
</row>
<row>
<entry>assign</entry>
<entry>cha<EFBFBD>ne de caract<63>res</entry>
<entry>Non</entry>
<entry><emphasis>n/a</emphasis></entry>
<entry>Le nom de la variable dans laquelle sera assign<67>e
la sortie de include</entry>
</row>
<row>
<entry>[var ...]</entry>
<entry>[type de variable]</entry>
<entry>Non</entry>
<entry><emphasis>n/a</emphasis></entry>
<entry>Variables <20> passer au template</entry>
</row>
</tbody>
</tgroup>
</informaltable>
<example>
2005-09-03 08:53:14 +00:00
<title>fonction {include}</title>
<programlisting>
<![CDATA[
<html>
<head>
<title>{$title}</title>
</head>
<body>
2005-12-01 20:28:15 +00:00
{include file='page_header.tpl'}
2004-04-13 15:43:47 +00:00
2005-09-03 08:53:14 +00:00
{* body of template goes here *}
2005-12-01 20:28:15 +00:00
{include file='$tpl_name.tpl'} <-- remplace $tpl_name avec la valeur
2004-04-13 15:43:47 +00:00
2005-12-01 20:28:15 +00:00
{include file='page_footer.tpl'}
2005-09-03 08:53:14 +00:00
</body>
</html>
]]>
</programlisting>
2004-05-23 15:44:59 +00:00
</example>
<para>
Vous pouvez <20>galement passer des variables au template inclus
sous forme d'attributs. Les variables pass<73>es au template par ce moyen
ne sont accessibles que dans la port<72>e de ce dernier. Les variables
pass<73>es en tant qu'attribut remplacent les variables d<>j<EFBFBD> d<>finies,
qui auraient le m<>me nom.
</para>
<example>
2005-09-03 08:53:14 +00:00
<title>fonction {include}, passage de variables</title>
<programlisting>
2005-05-24 20:46:11 +00:00
<![CDATA[
2005-12-01 20:28:15 +00:00
{include file='header.tpl' title='Menu principal' table_bgcolor='#c0c0c0'}
2004-04-13 15:43:47 +00:00
{* Le corps du template vient ici *}
2005-12-01 20:28:15 +00:00
{include file='footer.tpl' logo='http://mon.example.com/logo.gif'}
2005-09-03 08:53:14 +00:00
]]>
</programlisting>
<para>o<EFBFBD> header.tpl est :</para>
<programlisting>
<![CDATA[
<table border='1' width='100%' bgcolor='{$table_bgcolor|default:"#0000FF"}'>
<tr><td>
<h1>{$title}</h1>
</td></tr>
</table>
]]>
</programlisting>
</example>
<example>
<title>{include} et assignement <20> une variable</title>
<para>Cet exemple assigne le contenu de nav.tpl <20> la variable $navbar,
qui est alors affich<63>e en haut et en bas de la page.
</para>
<programlisting>
<![CDATA[
<body>
2005-12-01 20:28:15 +00:00
{include file='nav.tpl' assign=navbar}
{include file='header.tpl' title='Main Menu' table_bgcolor='#c0c0c0'}
2005-09-03 08:53:14 +00:00
{$navbar}
{* body of template goes here *}
2005-12-01 20:28:15 +00:00
{include file='footer.tpl' logo='http://my.example.com/logo.gif'}
2005-09-03 08:53:14 +00:00
{$navbar}
</body>
2005-05-24 20:46:11 +00:00
]]>
</programlisting>
2004-05-23 15:44:59 +00:00
</example>
<para>
Utilisez la syntaxe <link
linkend="template.resources">ressource template</link> pour inclure
des fichiers situ<74>s en dehors du r<>pertoire $template_dir.
</para>
<example>
2005-09-03 08:53:14 +00:00
<title>fonction {include}, exemple de ressource template</title>
2005-05-24 20:46:11 +00:00
<programlisting>
<![CDATA[
2004-04-13 15:43:47 +00:00
{* chemin absolu *}
2005-12-01 20:28:15 +00:00
{include file='/usr/local/include/templates/header.tpl'}
2004-04-13 15:43:47 +00:00
{* chemin absolu (m<>me chose) *}
2005-12-01 20:28:15 +00:00
{include file='file:/usr/local/include/templates/header.tpl'}
2004-04-13 15:43:47 +00:00
{* chemin absolu windows (DOIT utiliser le pr<70>fixe "file:") *}
2005-12-01 20:28:15 +00:00
{include file='file:C:/www/pub/templates/header.tpl'}
2004-04-13 15:43:47 +00:00
{* inclusion d'une ressource template "db" *}
2005-12-01 20:28:15 +00:00
{include file='db:header.tpl'}
{* inclusion d'un template $variable - eg $module = 'contacts' *}
{include file="$module.tpl"}
{* ne fonctionne pas avec des simples guillemets ie aucun substitution de variables *}
{include file='$module.tpl'}
2005-05-24 20:46:11 +00:00
]]>
</programlisting>
2004-05-23 15:44:59 +00:00
</example>
2005-05-24 20:46:11 +00:00
<para>
Voir aussi
<link linkend="language.function.include.php">{include_php}</link>,
<link linkend="language.function.php">{php}</link>,
2005-09-03 08:53:14 +00:00
<link linkend="template.resources">les ressources de template</link> et
2005-05-24 20:46:11 +00:00
<link linkend="tips.componentized.templates">les templates composants</link>.
</para>
2004-04-13 15:43:47 +00:00
</sect1>
2005-05-26 18:10:32 +00:00
2004-04-13 15:43:47 +00:00
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"../../../../manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
2005-05-26 18:10:32 +00:00
-->