mirror of
				https://github.com/smarty-php/smarty.git
				synced 2025-10-31 12:21:36 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			156 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			156 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # {$smarty} reserved variable
 | |
| 
 | |
| The PHP reserved `{$smarty}` variable can be used to access several
 | |
| environment and request variables. The full list of them follows.
 | |
| 
 | |
| ## Request variables
 | |
| 
 | |
| The [request variables](https://www.php.net/reserved.variables) such as
 | |
| `$_GET`, `$_POST`, `$_COOKIE`, `$_SERVER`, `$_ENV` and `$_SESSION` can
 | |
| be accessed as demonstrated in the examples below:
 | |
| 
 | |
| ```smarty
 | |
| {* display value of page from URL ($_GET) http://www.example.com/index.php?page=foo *}
 | |
| {$smarty.get.page}
 | |
| 
 | |
| {* display the variable "page" from a form ($_POST['page']) *}
 | |
| {$smarty.post.page}
 | |
| 
 | |
| {* display the value of the cookie "username" ($_COOKIE['username']) *}
 | |
| {$smarty.cookies.username}
 | |
| 
 | |
| {* display the server variable "SERVER_NAME" ($_SERVER['SERVER_NAME'])*}
 | |
| {$smarty.server.SERVER_NAME}
 | |
| 
 | |
| {* display the system environment variable "PATH" *}
 | |
| {$smarty.env.PATH}
 | |
| 
 | |
| {* display the php session variable "id" ($_SESSION['id']) *}
 | |
| {$smarty.session.id}
 | |
| 
 | |
| {* display the variable "username" from merged get/post/cookies/server/env *}
 | |
| {$smarty.request.username}
 | |
| ```
 | |
| 
 | |
| > **Note**
 | |
| >
 | |
| > For historical reasons `{$SCRIPT_NAME}` is shorthand for
 | |
| > `{$smarty.server.SCRIPT_NAME}`.
 | |
| >
 | |
| >
 | |
| >     <a href="{$SCRIPT_NAME}?page=smarty">click me</a>
 | |
| >     <a href="{$smarty.server.SCRIPT_NAME}?page=smarty">click me</a>
 | |
| 
 | |
| > **Note**
 | |
| >
 | |
| > Although Smarty provides direct access to PHP super globals for
 | |
| > convenience, it should be used with caution. Directly accessing super
 | |
| > globals mixes underlying application code structure with templates. A
 | |
| > good practice is to assign specific needed values to template vars.
 | |
| 
 | |
| ## {$smarty.now}
 | |
| 
 | |
| The current [timestamp](https://www.php.net/function.time) can be accessed
 | |
| with `{$smarty.now}`. The value reflects the number of seconds passed
 | |
| since the so-called Epoch on January 1, 1970, and can be passed directly
 | |
| to the [`date_format`](../language-modifiers/language-modifier-date-format.md) modifier for
 | |
| display. Note that [`time()`](https://www.php.net/function.time) is called
 | |
| on each invocation; eg a script that takes three seconds to execute with
 | |
| a call to `$smarty.now` at start and end will show the three-second
 | |
| difference.
 | |
| 
 | |
| ```smarty
 | |
| {* use the date_format modifier to show current date and time *}
 | |
| {$smarty.now|date_format:'%Y-%m-%d %H:%M:%S'}
 | |
| ```
 | |
| 
 | |
| ## {$smarty.const}
 | |
| 
 | |
| You can access PHP constant values directly.
 | |
| 
 | |
| ```php
 | |
| <?php
 | |
| // the constant defined in php
 | |
| define('MY_CONST_VAL','CHERRIES');
 | |
| ```
 | |
| 
 | |
| Output the constant in a template with
 | |
| 
 | |
| ```smarty
 | |
| {$smarty.const.MY_CONST_VAL}
 | |
| ```
 | |
| 
 | |
| > **Note**
 | |
| >
 | |
| > Although Smarty provides direct access to PHP constants for
 | |
| > convenience, it is typically avoided as this is mixing underlying
 | |
| > application code structure into the templates. A good practice is to
 | |
| > assign specific needed values to template vars.
 | |
| 
 | |
| ## {$smarty.capture}
 | |
| 
 | |
| Template output captured via the built-in
 | |
| [`{capture}..{/capture}`](../language-builtin-functions/language-function-capture.md) function can be
 | |
| accessed using the `{$smarty.capture}` variable. See the
 | |
| [`{capture}`](../language-builtin-functions/language-function-capture.md) page for more information.
 | |
| 
 | |
| ## {$smarty.config}
 | |
| 
 | |
| `{$smarty.config}` variable can be used to refer to loaded [config
 | |
| variables](language-config-variables.md). `{$smarty.config.foo}` is a
 | |
| synonym for `{#foo#}`. See the
 | |
| [{config_load}](../language-builtin-functions/language-function-config-load.md) page for more info.
 | |
| 
 | |
| ## {$smarty.section}
 | |
| 
 | |
| The `{$smarty.section}` variables can be used to refer to
 | |
| [`{section}`](../language-builtin-functions/language-function-section.md) loop properties. These have
 | |
| some very useful values such as `.first`, `.index`, etc.
 | |
| 
 | |
| > **Note**
 | |
| >
 | |
| > The `{$smarty.foreach}` variable is no longer used with the new
 | |
| > [`{foreach}`](../language-builtin-functions/language-function-foreach.md) syntax, but is still
 | |
| > supported with Smarty 2.x style foreach syntax.
 | |
| 
 | |
| ## {$smarty.template}
 | |
| 
 | |
| Returns the name of the current template being processed (without the
 | |
| directory).
 | |
| 
 | |
| ## {$smarty.template_object}
 | |
| 
 | |
| Returns the template object of the current template being processed.
 | |
| 
 | |
| ## {$smarty.current_dir}
 | |
| 
 | |
| Returns the name of the directory for the current template being
 | |
| processed if it is loaded from the filesystem (the default).
 | |
| 
 | |
| ## {$smarty.version}
 | |
| 
 | |
| Returns the version of Smarty the template was compiled with.
 | |
| 
 | |
| ```smarty
 | |
| <div id="footer">Powered by Smarty {$smarty.version}</div>
 | |
| ```
 | |
| 
 | |
| ## {$smarty.block.child}
 | |
| 
 | |
| Returns block text from child template. See [Template
 | |
| inheritance](../../api/inheritance.md).
 | |
| 
 | |
| ## {$smarty.block.parent}
 | |
| 
 | |
| Returns block text from parent template. See [Template
 | |
| inheritance](../../api/inheritance.md)
 | |
| 
 | |
| ## {$smarty.ldelim}, {$smarty.rdelim}
 | |
| 
 | |
| These variables are used for printing the left-delimiter and
 | |
| right-delimiter value literally, the same as
 | |
| [`{ldelim},{rdelim}`](../language-builtin-functions/language-function-ldelim.md).
 | |
| 
 | |
| See also [assigned variables](language-assigned-variables.md) and [config
 | |
| variables](language-config-variables.md)
 |