


Using Smarty in PHP Part 4: Custom Variable Mediator_PHP Tutorial
In PHP, there are many functions for processing text. You can process the text you want to process through the function, then call assign() in the Smarty template engine to assign the value to a variable, and assign it to the template for display.
The variable mediator in Smarty is similar to the text processing function in PHP, but the syntax is different. In Smarty, it is directly followed by the mediator function name through "|". If there are parameters, they must be added after ":". If there are two parameters, just add them up.
Format: {$var|modifier1:"Parameter1":"Parameter2":Parameter3|modifier2|modifier3|...}
The file defining the mediator must be placed in Smarty, the specific path is: libs/plugins/. The file name must be in the Smarty format modifier.moderatorname.php
The following uses an example to demonstrate the use of custom variable mediators in Smarty
Program idea: Make two variable mediators. The functions are: one to convert text; one to intercept text.
init.inc.php (Smarty initialization file)
Define('ROOT_PATH', dirname(__FILE__)); //Set the website root directory
require ROOT_PATH.'/libs/Smarty.class.php'; //Load Smarty template engine
$_tpl = new Smarty(); //Create an instance object
$_tpl->template_dir = ROOT_PATH.'/tpl/'; //Set the template file directory
$_tpl->compile_dir = ROOT_PATH.'./com/'; //Set the compiled file directory
$_tpl->left_delimiter = '
$_tpl->right_delimiter = '}>'; //Set the right delimiter
?>
index.php(main file)
define('CONST_VAR', 'ABC');
require 'init.inc.php'; //Introduce template initialization file
global $_tpl;
$_str = 'abcdEFGHigklmnOPQRSTuvwsYz'; //Define a string
$_tpl->assign('str',$_str); $_tpl->assign('str',$_str); //Assign string to str
$_tpl->assign('str1',strtolower($_str)); //Convert all strings to lowercase and assign them to str1
$_tpl->assign('str2',strtoupper($_str)); //Convert all strings to uppercase and assign them to str2
$_tpl->assign('str3',ucfirst($_str)); //Convert all strings to uppercase and assign them to str3
$_tpl->assign('str4',substr($_str, 0,15).'...');//Intercept the first 15 characters of the string, replace the following characters with '...', and assign Give str4
$_tpl->assign('str5',strtoupper(substr($_str, 0,15)).'...'); //Intercept the first 15 characters of the string and convert them to uppercase, and use '.. .' instead and assign it to str4
$_tpl->display('index.tpl'); //Introduce template
?>
tpl/index.tpl
/libs/plugins/modifier.transform.php (Transform File Modifier)
/**
* smarty_modifier_transform
* * Variable mediator function for string conversion
* @param string $string Processing string
* @param string $type Processing type
*/
Function smarty_modifier_transform($string,$type) {
switch ($type) {
case 'upper' :
$str = strtoupper($string);
break;
case 'lower' :
$str = strtolower($string);
break;
case 'firstdx' :
$str = ucfirst($string);
break;
default:
$str = $string;
}
return $str;
}
?>
lib/plugins/modifier.subString.php (interception text modifier)
/**
* smarty_modifier_subString
* Process interception string mediator
* @param string $string Processing string
* @param int $start_num Starting position, default starts from the beginning
* @param int $end_num End position, default 20
* @param string $addTo Append string, default '...'
*/
Function smarty_modifier_subString($string,$start_num=0,$end_num=20,$addTo='...') {
$_str = '';
If (strlen(substr($string, $start_num, $end_num))>=$end_num) {
$_str = substr($string, $start_num, $end_num).$addTo;
} else {
$_str = substr($string, $start_num, $end_num);
}
return $_str;
}
?>
Execution result:
The above example shows that the mediator file must be placed in Smarty's plug-in directory plugins, and the naming must follow Smarty's rules, so that the mediator function you write can be called. Another point that needs to be explained is that the defined function name must also comply with Smarty's default naming rules, for example: smarty_modifier_XXX, and a modifier file can only contain one function, not multiple.
… Regarding Smary’s built-in mediator, the next section will introduce it

ThesecrettokeepingaPHP-poweredwebsiterunningsmoothlyunderheavyloadinvolvesseveralkeystrategies:1)ImplementopcodecachingwithOPcachetoreducescriptexecutiontime,2)UsedatabasequerycachingwithRedistolessendatabaseload,3)LeverageCDNslikeCloudflareforservin

You should care about DependencyInjection(DI) because it makes your code clearer and easier to maintain. 1) DI makes it more modular by decoupling classes, 2) improves the convenience of testing and code flexibility, 3) Use DI containers to manage complex dependencies, but pay attention to performance impact and circular dependencies, 4) The best practice is to rely on abstract interfaces to achieve loose coupling.

Yes,optimizingaPHPapplicationispossibleandessential.1)ImplementcachingusingAPCutoreducedatabaseload.2)Optimizedatabaseswithindexing,efficientqueries,andconnectionpooling.3)Enhancecodewithbuilt-infunctions,avoidingglobalvariables,andusingopcodecaching

ThekeystrategiestosignificantlyboostPHPapplicationperformanceare:1)UseopcodecachinglikeOPcachetoreduceexecutiontime,2)Optimizedatabaseinteractionswithpreparedstatementsandproperindexing,3)ConfigurewebserverslikeNginxwithPHP-FPMforbetterperformance,4)

APHPDependencyInjectionContainerisatoolthatmanagesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itactsasacentralhubforcreatingandinjectingdependencies,thusreducingtightcouplingandeasingunittesting.

Select DependencyInjection (DI) for large applications, ServiceLocator is suitable for small projects or prototypes. 1) DI improves the testability and modularity of the code through constructor injection. 2) ServiceLocator obtains services through center registration, which is convenient but may lead to an increase in code coupling.

PHPapplicationscanbeoptimizedforspeedandefficiencyby:1)enablingopcacheinphp.ini,2)usingpreparedstatementswithPDOfordatabasequeries,3)replacingloopswitharray_filterandarray_mapfordataprocessing,4)configuringNginxasareverseproxy,5)implementingcachingwi

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SublimeText3 Chinese version
Chinese version, very easy to use

WebStorm Mac version
Useful JavaScript development tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver Mac version
Visual web development tools
