Jump to content

Smarty (template engine): Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
X2wg (talk | contribs)
See also: bullets fix
m Further reading: refs using AWB
Line 50: Line 50:


==Further reading==
==Further reading==
* {{cite book |title=Smarty PHP Template Programming And Applications |author=Hasin Hayder, J. P. Maia, Lucian Gheorghe |isbn=978-1-904-81140-4 |year=2006}}
* {{cite book |title=Smarty PHP Template Programming And Applications |author1=Hasin Hayder |author2=J. P. Maia |author3=Lucian Gheorghe |isbn=978-1-904-81140-4 |year=2006}}


== See also ==
== See also ==

Revision as of 22:28, 5 June 2016

Smarty
Developer(s)Monte Ohrt, Messju Mohr, Uwe Tews
Stable release
3.1.29 / 21 December 2015; 9 years ago (2015-12-21)[1]
Repository
Written inPHP
TypeTemplate Engine
LicenseLGPL
Websitewww.smarty.net

Smarty is a web template system written in PHP. Smarty is primarily promoted as a tool for separation of concerns.[2] Smarty is intended to simplify compartmentalization, allowing the front-end of a web page to change separately from its back-end. Ideally, this lowers costs and minimizes the efforts associated with software maintenance.

Smarty generates web content through the placement of special Smarty tags within a document. These tags are processed and substituted with other code. Tags are directives for Smarty that are enclosed by template delimiters. These directives can be variables, denoted by a dollar sign ($), functions, logical or loop statements. Smarty allows PHP programmers to define custom functions that can be accessed using Smarty tags.

Smarty example

Since Smarty separates PHP from HTML, there are two files — one contains the presentation code: an HTML template, including Smarty variables and tags - {$title_text|escape} {$body_html} - which might look like this:

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="utf-8">
   <title>{$title_text|escape}</title>
</head>

<body> {* This is a little comment that won't be visible in the HTML source *}
{$body_html}
</body><!-- this is a little comment that will be seen in the HTML source -->
</html>

The business logic to use the Smarty template above could be as follows:

define('SMARTY_DIR', 'smarty-2.6.22/');
require_once(SMARTY_DIR . 'Smarty.class.php');

$smarty = new Smarty();
$smarty->template_dir = './templates/';
$smarty->compile_dir = './templates/compile/';

$smarty->assign('title_text', 'TITLE: This is the Smarty basic example ...');
$smarty->assign('body_html', '<p>BODY: This is the message set using assign()</p>');

$smarty->display('index.tpl');

Further reading

  • Hasin Hayder; J. P. Maia; Lucian Gheorghe (2006). Smarty PHP Template Programming And Applications. ISBN 978-1-904-81140-4.

See also

References

  1. ^ https://github.com/smarty-php/smarty/blob/v3.1.29/change_log.txt
  2. ^ Parr, Terence John (2004). Enforcing strict model-view separation in template engines. Proceedings of the 13th international conference on World Wide Web. ISBN 1-58113-844-X.