mirror of
				https://github.com/smarty-php/smarty.git
				synced 2025-11-03 22:01:36 +01:00 
			
		
		
		
	
		
			
	
	
		
			117 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
		
		
			
		
	
	
			117 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
| 
								 | 
							
								<?xml version="1.0" encoding="iso-8859-1"?>
							 | 
						|||
| 
								 | 
							
								<!-- $Revision$ -->
							 | 
						|||
| 
								 | 
							
								   <sect1 id="plugins.modifiers"><title>Modificatori</title>
							 | 
						|||
| 
								 | 
							
								    <para>
							 | 
						|||
| 
								 | 
							
								     I modificatori sono piccole funzioni che vengono applicate ad 
							 | 
						|||
| 
								 | 
							
								     una variabile del template prima che venga visualizzata o usata
							 | 
						|||
| 
								 | 
							
								     in qualche altro contesto. I modificatori possono essere
							 | 
						|||
| 
								 | 
							
								     concatenati.
							 | 
						|||
| 
								 | 
							
								    </para>
							 | 
						|||
| 
								 | 
							
								    <funcsynopsis>
							 | 
						|||
| 
								 | 
							
								     <funcprototype>
							 | 
						|||
| 
								 | 
							
								      <funcdef>mixed <function>smarty_modifier_<replaceable>name</replaceable></function></funcdef>
							 | 
						|||
| 
								 | 
							
								      <paramdef>mixed <parameter>$value</parameter></paramdef>
							 | 
						|||
| 
								 | 
							
								      <paramdef>[mixed <parameter>$param1</parameter>, ...]</paramdef>
							 | 
						|||
| 
								 | 
							
								     </funcprototype>
							 | 
						|||
| 
								 | 
							
								    </funcsynopsis>
							 | 
						|||
| 
								 | 
							
								    <para>
							 | 
						|||
| 
								 | 
							
								     Il primo parametro passato al plugin modificatore <20> il valore sul
							 | 
						|||
| 
								 | 
							
								     quale il modificatore stesso deve operare. Gli altri parametri
							 | 
						|||
| 
								 | 
							
								     possono essere opzionali, a seconda del tipo di operazione che
							 | 
						|||
| 
								 | 
							
								     deve essere eseguita.
							 | 
						|||
| 
								 | 
							
								    </para>
							 | 
						|||
| 
								 | 
							
								    <para>
							 | 
						|||
| 
								 | 
							
								     Il modificatore deve restituire il risultato della sua esecuzione.
							 | 
						|||
| 
								 | 
							
								    </para>
							 | 
						|||
| 
								 | 
							
								    <para>
							 | 
						|||
| 
								 | 
							
								     Vedere anche
							 | 
						|||
| 
								 | 
							
								     <link linkend="api.register.modifier">register_modifier()</link>,
							 | 
						|||
| 
								 | 
							
								     <link linkend="api.unregister.modifier">unregister_modifier()</link>.
							 | 
						|||
| 
								 | 
							
								    </para>
							 | 
						|||
| 
								 | 
							
								    <example>
							 | 
						|||
| 
								 | 
							
								     <title>un semplice plugin modificatore</title>
							 | 
						|||
| 
								 | 
							
								     <para>
							 | 
						|||
| 
								 | 
							
								      Questo plugin fondamentalmente crea un sinonimo per una delle
							 | 
						|||
| 
								 | 
							
								      funzioni incorporate in PHP. Non prevede parametri aggiuntivi.
							 | 
						|||
| 
								 | 
							
								     </para>
							 | 
						|||
| 
								 | 
							
								     <programlisting role="php">
							 | 
						|||
| 
								 | 
							
								<![CDATA[
							 | 
						|||
| 
								 | 
							
								<?php
							 | 
						|||
| 
								 | 
							
								/*
							 | 
						|||
| 
								 | 
							
								 * Smarty plugin
							 | 
						|||
| 
								 | 
							
								 * -------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								 * File:     modifier.capitalize.php
							 | 
						|||
| 
								 | 
							
								 * Type:     modifier
							 | 
						|||
| 
								 | 
							
								 * Name:     capitalize
							 | 
						|||
| 
								 | 
							
								 * Purpose:  capitalize words in the string
							 | 
						|||
| 
								 | 
							
								 * -------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								 */
							 | 
						|||
| 
								 | 
							
								function smarty_modifier_capitalize($string)
							 | 
						|||
| 
								 | 
							
								{
							 | 
						|||
| 
								 | 
							
								    return ucwords($string);
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								?>
							 | 
						|||
| 
								 | 
							
								]]>
							 | 
						|||
| 
								 | 
							
								</programlisting>
							 | 
						|||
| 
								 | 
							
								    </example>
							 | 
						|||
| 
								 | 
							
								    <para></para>
							 | 
						|||
| 
								 | 
							
								    <example>
							 | 
						|||
| 
								 | 
							
								     <title>un plugin modificatore pi<70> complesso</title>
							 | 
						|||
| 
								 | 
							
								     <programlisting role="php">
							 | 
						|||
| 
								 | 
							
								<![CDATA[
							 | 
						|||
| 
								 | 
							
								<?php
							 | 
						|||
| 
								 | 
							
								/*
							 | 
						|||
| 
								 | 
							
								 * Smarty plugin
							 | 
						|||
| 
								 | 
							
								 * -------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								 * File:     modifier.truncate.php
							 | 
						|||
| 
								 | 
							
								 * Type:     modifier
							 | 
						|||
| 
								 | 
							
								 * Name:     truncate
							 | 
						|||
| 
								 | 
							
								 * Purpose:  Truncate a string to a certain length if necessary,
							 | 
						|||
| 
								 | 
							
								 *           optionally splitting in the middle of a word, and 
							 | 
						|||
| 
								 | 
							
								 *           appending the $etc string.
							 | 
						|||
| 
								 | 
							
								 * -------------------------------------------------------------
							 | 
						|||
| 
								 | 
							
								 */
							 | 
						|||
| 
								 | 
							
								function smarty_modifier_truncate($string, $length = 80, $etc = '...',
							 | 
						|||
| 
								 | 
							
								                                  $break_words = false)
							 | 
						|||
| 
								 | 
							
								{
							 | 
						|||
| 
								 | 
							
								    if ($length == 0)
							 | 
						|||
| 
								 | 
							
								        return '';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    if (strlen($string) > $length) {
							 | 
						|||
| 
								 | 
							
								        $length -= strlen($etc);
							 | 
						|||
| 
								 | 
							
								        $fragment = substr($string, 0, $length+1);
							 | 
						|||
| 
								 | 
							
								        if ($break_words)
							 | 
						|||
| 
								 | 
							
								            $fragment = substr($fragment, 0, -1);
							 | 
						|||
| 
								 | 
							
								        else
							 | 
						|||
| 
								 | 
							
								            $fragment = preg_replace('/\s+(\S+)?$/', '', $fragment);
							 | 
						|||
| 
								 | 
							
								        return $fragment.$etc;
							 | 
						|||
| 
								 | 
							
								    } else
							 | 
						|||
| 
								 | 
							
								        return $string;
							 | 
						|||
| 
								 | 
							
								}
							 | 
						|||
| 
								 | 
							
								?>
							 | 
						|||
| 
								 | 
							
								]]>
							 | 
						|||
| 
								 | 
							
								     </programlisting>
							 | 
						|||
| 
								 | 
							
								    </example>
							 | 
						|||
| 
								 | 
							
								   </sect1>
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								<!-- 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
							 | 
						|||
| 
								 | 
							
								-->
							 |