首页  >  文章  >  后端开发  >  thinkPHP2.1自定义标签库的导入方法的介绍

thinkPHP2.1自定义标签库的导入方法的介绍

不言
不言原创
2018-07-03 16:48:581386浏览

这篇文章主要介绍了thinkPHP2.1自定义标签库的导入方法,详细分析了thinkPHP标签库的定义、使用及自动导入相关技巧,需要的朋友可以参考下

本文详细讲述了thinkPHP2.1自定义标签库的导入方法。分享给大家供大家参考,具体如下:

TP的手册似乎跟不上节奏, 对自定义标签只是寥寥几句, 摸索了N久, 终于将自定义的标签进行了导入. 心得如下:

1. 情况:  新建自定义的标签库类: @.Mylib.Tag.TagLibTest — 懂TP的应该知道这代表的路径

使用Examples下的Tag演示文件

<?php
// +-----------------------------------------------------------
// | ThinkPHP
// +------------------------------------------------------------
// | Copyright (c) 2009 http://thinkphp.cn All rights reserved.
// +------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +------------------------------------------------------------
// | Author: liu21st <liu21st @gmail.com="">
// +------------------------------------------------------------
// $Id$
import(&#39;TagLib&#39;);
class TagLibArticle extends TagLib{
 // 标签定义
 protected $tags = array(
  // 标签定义:
  //attr 属性列表 close 是否闭合(0 或者1 默认1) alias 标签别名 level 嵌套层次
  &#39;article&#39;=>array(&#39;attr&#39;=>&#39;name,field,limit,order,where,sql,key,mod&#39;,&#39;level&#39;=>3),
  );
 //定义查询数据库标签
 public function _article($attr,$content) {
  $tag = $this->parseXmlAttr($attr,&#39;article&#39;);
  $result = !empty($tag[&#39;result&#39;])?$tag[&#39;result&#39;]:&#39;article&#39;; //定义数据查询的结果存放变量
  $key = !empty($tag[&#39;key&#39;])?$tag[&#39;key&#39;]:&#39;i&#39;;
  $mod = isset($tag[&#39;mod&#39;])?$tag[&#39;mod&#39;]:&#39;2&#39;;
  if ($tag[&#39;name&#39;])
  { //根据用户输入的值拼接查询条件
   $sql = "M(&#39;{$tag[&#39;name&#39;]}&#39;)->";
   $sql .= ($tag[&#39;field&#39;])?"field({$tag[&#39;field&#39;]})->":&#39;&#39;;
   $sql .= ($tag[&#39;order&#39;])?"order({$tag[&#39;order&#39;]})->":&#39;&#39;;
   $sql .= ($tag[&#39;where&#39;])?"where({$tag[&#39;where&#39;]})->":&#39;&#39;;
   $sql .= "select()";
  }else{
   if (!$tag[&#39;sql&#39;]) return &#39;&#39;; //排除没有指定model名称,也没有指定sql语句的情况
   $sql .= "M()->query(&#39;{$tag[&#39;sql&#39;]}&#39;)";
  }
  //下面拼接输出语句
  $parsestr = &#39;<?php $_result=&#39;.$sql.&#39;; if ($_result): $&#39;.$key.&#39;=0;&#39;;
  $parsestr .= &#39;foreach($_result as $key=>$&#39;.$result.&#39;):&#39;;
  $parsestr .= &#39;++$&#39;.$key.&#39;;$mod = ($&#39;.$key.&#39; % &#39;.$mod.&#39; );?>&#39;;
  $parsestr .= $content;//解析在article标签中的内容
  $parsestr .= &#39;<?php endforeach; endif;?>&#39;;
  return $parsestr;
 }
}
?></liu21st>

然后在项目下的Conf目录新建taglibs.php文件, 内容:

<?php
return array(
 &#39;article&#39;=>&#39;@.TagLib.TagLibarticle&#39;,
);
?>

这样就可以模板里使用了:

<tagLib name="article" />
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 <title>ThinkPHP示例:自定义标签</title>
<link rel=&#39;stylesheet&#39; type=&#39;text/css&#39; href=&#39;__PUBLIC__/Css/common.css&#39;>
 </head>
 <body>
 <p class="main">
 <h2>ThinkPHP示例之自定义标签:定义查询数据库的标签</h2>
 本示例定义一个查询数据库的标签,可以使模板直接按条件查找指定的数据库并列表显示,本例仅是展示自定义标签的方便之处,可以进一步扩充和完善,打造属于自已的标签体系
 <table cellpadding=2 cellspacing=2>
 <thead>
 <tr>
 <td class="tLeft" width="8%">序列</td><td class="tLeft" width="12%">标题</td><td>内容</td>
 </tr>
</thead>
  <article:article name="form" limit="10">
  <tr>
   <td>{$article.id}</td>
   <td>{$article.title}</td>
   <td>{$article.content}</td>
  </tr>
 </article:article>
<tr>
 <td colspan=&#39;3&#39;>
 <hr> 示例源码<br/>控制器自定义标签类<br/> <php>highlight_file(LIB_PATH.&#39;TagLib/TagLibarticle.class.php&#39;);</php></td>
 </tr>
 </table>
</p>
 </body>
</html>

这是很简单的情况, 但是我的想法是要求自定义标签库能自动导入, 这样就不用在每一个模板里第一行加上类似 d1f050571ea67180877e1dffe40ac203 这样的标签了.

只是这遇到了一点问题

2. 自动导入自定义标签库

在config.php文件里加上:

&#39;TAGLIB_PRE_LOAD&#39; => &#39;article&#39; ,

清除缓存, 提示错误 "实例化一个不存在的类!" ;

使用在TP官方论坛转了几圈, 发现只有一个方式能解决: 使用别名导入, 即在TP框架里的commonn/alias.php下添加导入的路径:

如:

&#39;TagLibArticle&#39; => THINK_PATH.&#39;/Lib/Think/Template/TagLib/TagLibArticle.class.php&#39;,

还有一些修改Template类源码的方案, 不好使 — 因为通常我不希望为了一点小问题修改核心.

于是想到Action的导入:

在自己的项目基类BaseAction.class.php里加入导入:

function _initialize() {
 import("@.Mylibs.Tag.TagLibArticle");
}

刷新缓存, 问题解决…

这方案简单好用.

补充:

使用TP的自动加载配置更加快捷:

&#39;APP_AUTOLOAD_PATH&#39;=> &#39;Think.Util.,@.Mylibs.Tag.&#39;,

最终方案:

1. 建立Mylibs.Tag.TagLibTest — 自定义标签库

2. 配置:

&#39;APP_AUTOLOAD_PATH&#39;=> &#39;Think.Util.,@.Mylibs.Tag.&#39;,
'TAGLIB_PRE_LOAD' => 'test' ,

删除缓存后既可正常使用.

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

thinkPHP框架对接支付宝即时到账接口回调的方法介绍

thinkphp中常用的系统常量和系统变量的介绍

ThinkPHP写数组插入与获取最新插入数据ID的方法

以上是thinkPHP2.1自定义标签库的导入方法的介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn