smarty block_function

什么是block function

如果你使用过smarty3,一定对下面的代码不陌生。

{block}...{/block}
  • 1
  • 1

block function的形式同上面类似。

{func}...{/func}
  • 1
  • 1

它用标签圈起一个块,然后对这个块的内容进行操作。

如何定义block function

smarty_block_name($params, $content, $template, &$repeat);
  • 1
  • 1

这是手册中给出的定义,说明如下: 
1. 默认你的函数将被Smarty调用两次,分别在开始标签位置和结束标签位置。 
2. 函数将以以下方式输出内容到页面: 
* 直接echo 
* 对应结束标签位置的调用,函数的返回值会显示在页面。 
* 从smarty3.1开始,开始标签位置的调用,函数的返回值也会显示在页面。 
3. 模板中传递给块函数的属性都包含在$params参数数组中 
4. $content的值,取决于函数在执行开始标签还是结束标签。当在开始标签时,它会是null; 当在结束标签时,它会是模板块里面全部的内容。 
5. $repeat是一个引用值,能控制块可以被显示多少次。当块函数被第一次调用时(开始标签),$repeat默认是true; 随后的调用(结束标签)都是false。每将$repeat被设置成true时,block function都会被再次执行。

结合例子的进一步说明

example 1

block.my_test.PHP

function smarty_block_my_test($params, $content, $smarty, &$repeat){
    if ($repeat){
        echo "start tag:<br>";
        var_dump($params);
        return "content: {$content}<br>";
    }

    if(!$repeat){
        echo "end tag:<br>";
        var_dump($params);
        return "content: {$content}";
    }
}   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

tpl.test.htm

{my_test name="ball" gender="male"}
this is my test
{/my_test}
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

页面输出

start tag:
array(2) { ‘name‘ => string(4) "ball" ‘gender‘ => string(4) "male" } content:
end tag:
array(2) { ‘name‘ => string(4) "ball" ‘gender‘ => string(4) "male" } content: this is my test
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

本例说明 
1. my_test的确被调用两次 
2. {my_test}(标签开始)处的调用,对应$repeat = true, 且此时$content值为空。{/my_test}(标签结束)处的调用,对应$repeat = false, 此时$content的值为block块中的内容(this is my test)。 
3. block的属性(name, gender)可以通过$parmas取到,且在任何位置(标签的开始和结束)都可以取到。 
4. echo和return的值,都将在页面显示。

example 2 – 对$repeat的说明

改写下smarty_block_my_test,实现这样一个功能:将{my_test}{/my_test}中的内容重复若干次,次数由属性值count指定。 
block.my_test.php

function smarty_block_my_test($params, $content, $smarty, &$repeat){
    $count = $params[‘count‘];
    static $num = 0;

    if(!$repeat){
        $num++;

        if ($num < $count ){
            $repeat = true;
        }

        return "{$content}--{$num}<br>";
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

tpl.test.htm

{my_test count=3}
this is my test
{/my_test}
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

页面输出

this is my test --1
this is my test --2
this is my test --3
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

这个例子着重说明了$repeat的作用,只要$repeat被设为true,{my_test}{/my_test}就会被再次调用

example 3 – 实际应用

一个实际中的例子是这样的:我们希望输出一个,可以根据参数决定的href, color, class等值。 
block.html_link.php

function smarty_block_html_link($params, $content, $smarty, &$repeat){
    if(!$repeat){
        $href = $params[‘href‘];

        $color = ‘‘;
        if(isset($params[‘color‘])){
            $color = sprintf("style=‘color:%s‘", $params[‘color‘]);
        }

        $class = ‘‘;
        if(isset($params[‘class‘])){
            $class = sprintf("class=‘%s‘", $params[‘class‘]);
        }

        $str = sprintf("<a href=‘%s‘ %s %s>%s</a>", $href, $color, $class, $content);

        return $str;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

tpl中的代码可能是这样的

{html_link href="http://www.sogou.com" color="green"}
this is a real case
{/html_link}
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

页面中得到的html源码如下

<a href=‘http://www.sogou.com‘ style=‘color:green‘ >
this is a test
</a>
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

如何让你的block function生效

有下面两种方式: 
1. 使用registerPlungin() 具体可参见手册,有明确的注册block function的例子 
2. 使用addPluginsDir(), 将插件(block.html_link.php)所在的目录告知smarty。此种方式要注意文件名和函数的命名。

时间: 2024-10-27 13:29:10

smarty block_function的相关文章

smarty变量调节器如何使用

smarty变量调节器是用来改变显示的值,不改变变量的值.这里给大家总结了一下,希望对大家的smarty学习有参考意义. 1.capitalize[首字符大写]  调用方法: <?php$smarty->assign('articleTitle', 'next x-men film, x3, delayed.');?> 调用方法: {$articleTitle} {$articleTitle|capitalize} {$articleTitle|capitalize:true} 实现结果

Smarty 函数讲解

这里给大家总结了几种Smarty 函数并分别详细讲解了.如果你正在学习Smarty  ,希望这篇文章对你有用. html_checkboxes 自定义函数 html_checkboxes 根据给定的数据创建复选按钮组. 该函数可以指定哪些元素被选定. 要么必须指定 values 和 ouput 属性,要么指定 options 替代. 所有的输出与 XHTML 兼容 html_checkbox用来用给定的数据创建checkbox.name表示checkbox的名称,values表示checkbox

smarty变量调节器

1.capitalize[首字符大写]  调用方法: <?php$smarty->assign('articleTitle', 'next x-men film, x3, delayed.');?> 调用方法: {$articleTitle} {$articleTitle|capitalize} {$articleTitle|capitalize:true} 实现结果: next x-men film, x3, delayed. Next X-Men Film, x3, Delayed.

Smarty 模板引擎下缓存设置

缓存:就是将用户重复使用的内容进行缓存生成HTML内容. 缓存类型 全局缓存: 将整个页面内容都生成静态内容. Cache_dir: 缓存目录配置 Cache_lifetime:缓存的有效周期 Cacheing:设置是否开启缓存 局部缓存: 控制整个页面中的某个内容缓存,或者某个内容不缓存. insert函数调用的内容不缓存: 定义insert类型的函数: Smarty 2.x版本: Function insert_插件名(参数列表){ 功能代码 } Smarty 3.x版本: Function

Smarty的应用

smarty模板的核心是一个类,下载好的模板中有这么几个重要的文件夹 (1)libs核心文件夹(2)int.inc.php这是入口文件(3)plugins:自己写的插件文件夹(4)templates_c:存放编译好的文件(5)int.inc.php这是入口文件(6)定义好常量:不能修改 二.怎么用模板? 模板页面1.引入模板的入口文件include("入口文件路径位置"); 2.直接用对象提供一个方法:向模板中注册变量的方法(assign(名字,值)$smarty->assign

前端学PHP之Smarty模板引擎

前面的话 对PHP来说,有很多模板引擎可供选择,但Smarty是一个使用PHP编写出来的,是业界最著名.功能最强大的一种PHP模板引擎.Smarty像PHP一样拥有丰富的函数库,从统计字数到自动缩进.文字环绕以及正则表达式都可以直接使用,如果觉得不够,SMARTY还有很强的扩展能力,可以通过插件的形式进行扩充.另外,Smarty也是一种自由软件,用户可以自由使用.修改,以及重新分发该软件.本文将详细介绍Smarty模板引擎 概述 Smarty是一个php模板引擎.更准确的说,它分离了逻辑程序和外

Smarty的基本使用

含义: Smarty是PHP的一个引擎模板,可以更好的进行逻辑与显示的分离,即我们常说的MVC,这个引擎的作用就是将C分离出来. 环境需求:PHP5.2或者更高版本 我使用的环境是:PHP5.3,windows 环境 安装: 在网上下载Smarty包直接将其解压,我们需要的仅仅是里面的libs文件夹.Libs文件里面都是库文件,我们不应该修改里面的任何内容.解压完毕后就直接将libs文件夹放入到我们需要使用的网站根目录. 使用: 首先打开Smarty.class.php文件看看里面的一些代码:

模板引擎(smarty)知识点总结II

今天咱们继续来学习smarty!!! 知识点1:对于三种变量 常量的引用 有哪三种变量?a.assign赋值 b.系统保留变量(包括:$smarty.get,$smarty.post,$smarty.cookie,$smarty.session,$smarty.file,$smarty.request,$smarty.server,$smarty.env)c.配置文件   一般配置文件以.conf为主 $id = $_GET['id']?(int)$_GET['id']:0; #要在html页面

PHP Smarty 页面静态化加分页和缓存控制

PHP页面 <?php  //打开输出控制缓冲 ob_start(); //新建模板文件 $file = "./cache/newindex{$_GET['page']}.html"; $cachetime = 10; const  DSN = 'mysql:host=localhost;dbname=test'; const   DBUSER = 'root'; const   DBPWD     = 'root'; //模板不存在或者超过缓存时间才生成缓存模板 if(!fil