PHP Classes

File: htdocs/xoops_lib/vendor/smarty/smarty/docs/programmers/advanced-features/advanced-features-outputfilters.md

Recommend this page to a friend!
  Packages of Michael Beck   Xoops 2.5   htdocs/xoops_lib/vendor/smarty/smarty/docs/programmers/advanced-features/advanced-features-outputfilters.md   Download  
File: htdocs/xoops_lib/vendor/smarty/smarty/docs/programmers/advanced-features/advanced-features-outputfilters.md
Role: Example script
Content type: text/markdown
Description: Example script
Class: Xoops 2.5
Modular content management publication system
Author: By
Last change:
Date: 1 month ago
Size: 1,638 bytes
 

Contents

Class file image Download

Output Filters {#advanced.features.outputfilters}

When the template is invoked via display() or fetch(), its output can be sent through one or more output filters. This differs from postfilters because postfilters operate on compiled templates before they are saved to the disk, whereas output filters operate on the template output when it is executed.

Output filters can be either registered or loaded from the plugins directory by using the loadFilter() method or by setting the $autoload_filters variable. Smarty will pass the template output as the first argument, and expect the function to return the result of the processing.

<?php
// put this in your application
function protect_email($tpl_output, Smarty_Internal_Template $template)
{
    $tpl_output =
       preg_replace('!(\S+)@([a-zA-Z0-9\.\-]+\.([a-zA-Z]{2,3}|[0-9]{1,3}))!',
                    '$1%40$2', $tpl_output);
    return $tpl_output;
}

// register the outputfilter
$smarty->registerFilter("output","protect_email");
$smarty->display("index.tpl');

// now any occurrence of an email address in the template output will have
// a simple protection against spambots
?>

    

See also registerFilter(), loadFilter(), $autoload_filters, postfilters and $plugins_dir.