mirror of
https://github.com/smarty-php/smarty.git
synced 2025-07-27 22:47:14 +02:00
Feature/add docs (#689)
* Add converted docs repo * Set theme jekyll-theme-minimal * Removed BC docs, added TOC * Added TOCs, rewrote most important links in documentation. Linked README to new Github Pages site * some link fixes
This commit is contained in:
94
docs/programmers/plugins/plugins-functions.md
Normal file
94
docs/programmers/plugins/plugins-functions.md
Normal file
@ -0,0 +1,94 @@
|
||||
Template Functions {#plugins.functions}
|
||||
==================
|
||||
|
||||
void
|
||||
|
||||
smarty\_function\_
|
||||
|
||||
name
|
||||
|
||||
array
|
||||
|
||||
\$params
|
||||
|
||||
object
|
||||
|
||||
\$template
|
||||
|
||||
All [attributes](#language.syntax.attributes) passed to template
|
||||
functions from the template are contained in the `$params` as an
|
||||
associative array.
|
||||
|
||||
The output (return value) of the function will be substituted in place
|
||||
of the function tag in the template, eg the
|
||||
[`{fetch}`](#language.function.fetch) function. Alternatively, the
|
||||
function can simply perform some other task without any output, eg the
|
||||
[`{assign}`](#language.function.assign) function.
|
||||
|
||||
If the function needs to assign some variables to the template or use
|
||||
some other Smarty-provided functionality, it can use the supplied
|
||||
`$template` object to do so eg `$template->foo()`.
|
||||
|
||||
|
||||
<?php
|
||||
/*
|
||||
* Smarty plugin
|
||||
* -------------------------------------------------------------
|
||||
* File: function.eightball.php
|
||||
* Type: function
|
||||
* Name: eightball
|
||||
* Purpose: outputs a random magic answer
|
||||
* -------------------------------------------------------------
|
||||
*/
|
||||
function smarty_function_eightball($params, Smarty_Internal_Template $template)
|
||||
{
|
||||
$answers = array('Yes',
|
||||
'No',
|
||||
'No way',
|
||||
'Outlook not so good',
|
||||
'Ask again soon',
|
||||
'Maybe in your reality');
|
||||
|
||||
$result = array_rand($answers);
|
||||
return $answers[$result];
|
||||
}
|
||||
?>
|
||||
|
||||
which can be used in the template as:
|
||||
|
||||
Question: Will we ever have time travel?
|
||||
Answer: {eightball}.
|
||||
|
||||
|
||||
|
||||
<?php
|
||||
/*
|
||||
* Smarty plugin
|
||||
* -------------------------------------------------------------
|
||||
* File: function.assign.php
|
||||
* Type: function
|
||||
* Name: assign
|
||||
* Purpose: assign a value to a template variable
|
||||
* -------------------------------------------------------------
|
||||
*/
|
||||
function smarty_function_assign($params, Smarty_Internal_Template $template)
|
||||
{
|
||||
if (empty($params['var'])) {
|
||||
trigger_error("assign: missing 'var' parameter");
|
||||
return;
|
||||
}
|
||||
|
||||
if (!in_array('value', array_keys($params))) {
|
||||
trigger_error("assign: missing 'value' parameter");
|
||||
return;
|
||||
}
|
||||
|
||||
$template->assign($params['var'], $params['value']);
|
||||
|
||||
}
|
||||
?>
|
||||
|
||||
|
||||
|
||||
See also: [`registerPlugin()`](#api.register.plugin),
|
||||
[`unregisterPlugin()`](#api.unregister.plugin).
|
Reference in New Issue
Block a user