块函数的形式是这样的:{func} .. {/func}。换句话说,它们被封闭在一个模板区域内,然后对该区域的内容进行操作。默认地,你的函数实现会被Smarty调用两次:一次是在开始标签,另一次是在闭合标签。块函数在模板中使用和函数还是有一些区别的,但自定义添加的方式差距不大,也可以使用两种方式进行添加。使用Smarty对象中的addPluginsDir()方法动态注册时,将第一个参数改为“block”。如果以特定文件的方式扩充块函数,文件的命名规则是“block.块函数名.php”的结构,函数命令规则是“smarty_block_块函数名($params, $content, $smarty,&$repeat)”。只有块函数的开始标签具有属性,所有属性包含在作为关联数组的$params变量中,经由模板传递给模板函数。当处理闭合标签时,函数同样可访问开始标签的属性。$content变量值取决于你的函数是被开始标签调用还是被闭合标签调用。假如是开始标签,则变量值将为NULL,如果是闭合标签,则$content变量值为模板块的内容。请注意这时模板块已经被Smarty处理过,因此你所接收到的是模板的输出而不是模板资源。&$repeat参数通过引用传递给函数执行,并为其提供控制块显示多少次的可能性。在默认情况下,在首次调用块函数(块开始标签)时&$repeat变量为true,在随后的所有块函数(闭合标签)调用中其值始终为false。函数每次执行返回的&$repeat值为true时,{func} .. {/func}之间的内容会被求值,同时参数$content里的新块内容会再次调用执行函数(运行方法有点类似于递归函数)。如果你嵌套了块函数,可以通过$smarty->_tag_stack变量访问找出父块函数。

//函数中的$params代表标签中传入的参数的数组;变量 $content 的值取决于是否因开始标记或结束标
           //记或结束标记调用你的函数。假如是开始标记,它会是空的,如果是结束标记,它会是模板块的内容。
           //参数 &$repeat 通过参考引用传递给函数执行过程并为其提供一个可能值来控制显示块多少遍。默认情况下
           //首次调用块函数(块开始标记)时变量 $repeat 是真,在随后的所有块函数调用中其始终是假。每当函数执行
           //返回的 &$repeat 是真时,在{func} .. {/func}之间的内容再次求值,函数执行接收一个新块参数 $content
           //内容值被再次调用。
 
    function smarty_block_products($params, $content, &$smarty, &$repeat) {
 
        global $db, $config;
 
    //仅仅是获取一个和当前block相对应的值而已
        $l = count($smarty->_tag_stack);
        //指派变量名
        if(empty($params['name'])) $params['name'] = "products";
        //判断是否是第一次运行(前半部标签),如果这个变量存在了,那么说明数据已经被注册进$smarty->blocvars[$l]里面了
    //其中$smarty->blockvars是自定义的变量,smarty本身没有该属性,在smarty上面注册该变量的好处是, smarty每次都会默认以引用的方式进行传递,当然,如果你乐意,也可以使用$GLOBALS['blockvars'][$l]
    //
        if(empty($smarty->blockvars[$l])) {
            /*
            sql process
            */
            $smarty->blockvars[$l] = $db->get_results($sql);
            //如果没有数据,那就不用再执行了(repeat)
            if(!$smarty->blockvars[$l]) return $repeat = false;
            if(!empty($params['pager'])) $smarty->assign($params['pager'], $pager);
        }
 
 
        //利用each的特点,逐一遍历$smarty->blockvars[$l]子元素
        if(list($key, $item) = each($smarty->blockvars[$l])) {
            $repeat = true;
            //重要的,指派变量,以供结束标签显示(下一次调用)
            $smarty->assign($params['name'], $item);
        }
        else {
            $repeat = false;
            //清除each产生的指针记录,不解
            reset($smarty->blockvars[$l]);
        }
        //print 这里的$content其实是在上一次的运行中解析过(已经插入数据的最终结果)的$content,直接打印即可
        if(!is_null($content)) print $content;
 
        //循环结束时,清理变量
        if(!$repeat) $smarty->blockvars[$l] = array();
    }

smarty框架块函数的更多相关文章

  1. 第八十八天请假 PHP smarty模板 变量调节器,方法和块函数基本书写格式

    变量调节器 : 文件命名格式(modifier.名称.php)  前端调用方式<{变量|名称:参数:参数……}>可组合使用,用|隔开 <?php /* 命名格式 smarty_mod ...

  2. iOS Foundation 框架概述文档:常量、数据类型、框架、函数、公布声明

    iOS Foundation 框架概述文档:常量.数据类型.框架.函数.公布声明 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业 ...

  3. [Effective JavaScript 笔记]第15条:当心局部块函数声明笨拙的作用域

    嵌套函数声明.没有标准的方法在局部块里声明函数,但可以在另一个函数的顶部嵌套函数声明. function f(){return "global"} function test(x) ...

  4. 很少有人知道的c++中的try块函数

    c++有一些在现实世界中很少看到的结构.这些结构有着自己的用法,但是要特别小心保守的予以运用.就像是网站 The Old New Thing首页标题上面的说的那样: “代码通常被读的次数原因超过了被写 ...

  5. smarty的ASSIGN()函数

    http://blog.sina.com.cn/s/blog_6721f25c01011qdj.html 主要是把程序里面的值付给模板,因为使用smarty时,模板里面是没有PHP代码的,无法显示在操 ...

  6. block 块函数

    定义模块函数: <?php function smarty_block_text($args,$content,$smarty,$a) { $color=$args["color&qu ...

  7. smarty 内置函数if 等判断

    {if},{elseif},{else} Smarty的{if}条件判断和PHP的if 非常相似,只是增加了一些特性. 每个{if}必须有一个配对的{/if}. 也可以使用{else} 和 {else ...

  8. smarty内置函数

      1.{append} 追加 2.{assign} 赋值 3.{block} 块 4.{call} 调用 5.{capture}捕获 6.{config_load}用来从配置文件中加载config变 ...

  9. Xposed框架之函数Hook学习

    作者:Fly2015 Xposed是Android下Java层的开源Hook框架类似的有cydiasubstrate框架而且据说cydiasubstrate框架能实现Android的Java层和Nat ...

随机推荐

  1. (Android学习系列)二,窗口(Activity)的生命周期

    在Activity从创建到销毁的过程中需要在不同的阶段调用7个生命周期的方法这7个生命周期方法定义如下: protected void onCreate(Bundle savedInstanceSta ...

  2. Git 对象

    Git 提供了很多方法可以方便地访问 Git 库中的对象: ♦ 采用不分的 SHA1 哈希值.不必把 40 位的哈希值写全,只采用开头的部分(4 位以上),只要不与现有的其他哈希值冲突即可. ♦ 使用 ...

  3. ionic使用sass

    sass 是一个css的预编译器,常见的预编译器有less,sass,stylus等,目前sass似乎更受青睐一些,bootstrap的最新版本以及ionic 都是用sass来构建页面效果的.这篇文章 ...

  4. hdu 4010 Query on The Trees LCT

    支持:1.添加边 x,y2.删边 x,y3.对于路径x,y上的所有节点的值加上w4.询问路径x,y上的所有节点的最大权值 分析:裸的lct...rev忘了清零死循环了两小时... 1:就是link操作 ...

  5. Convolution and Deconvolution

    1.Introduction 2.Convolution 3.Deconvolution 4.Summary

  6. asp.net MVC EF Where 过滤条件怎么写

    做.Net开发的肯定都知道.Net Sql语句有个SqlParameter 一般用来做过滤判断逻辑写,那么到了EF 了还有这样的写法嘛?答案肯定是有的了,这里我只是把最粗糙和简单的写法罗列一些,具体封 ...

  7. 递归小Demo

    public class demo5 { public static void main(String[] args) {        //初始值为100         int n = 100;  ...

  8. 【BUG】---ionic tab-demo项目在modal页跳转URL改变页面不刷新,手动刷新后显示空白

    问题描述: 项目是基于ionic tab的demo,在modal上访问其他页面,地址栏变化了,但是页面不动没刷新,自己手动刷新呢,还是空白,可是访问的页面时有内容的啊 错误: 我的路由配置 .stat ...

  9. django 学习-15 .Django文件上传(用户注册)

    1.vim blog/views.py from django.shortcuts  import  render_to_responsefrom django.http   import HttpR ...

  10. 正则表达式删除指定的HTML 标签

    1.抓取某网页的数据后(比如描述),如果照原样显示的话,可能会因为它里面包含没有闭合的HTML标签而打乱了格式,也可能它里面用了比较让人 "费解" 的HTML标签,把预订的格式搅乱 ...