Home > Backend Development > PHP Tutorial > Introduction to the import method of thinkPHP2.1 custom tag library

Introduction to the import method of thinkPHP2.1 custom tag library

不言
Release: 2023-04-02 09:28:01
Original
1484 people have browsed it

This article mainly introduces the import method of thinkPHP2.1 custom tag library, and analyzes in detail the definition, use and automatic import related techniques of thinkPHP tag library. Friends in need can refer to the following

This article is detailed Describes the import method of thinkPHP2.1 custom tag library. I share it with you for your reference. The details are as follows:

TP’s manual seems to be unable to keep up with the pace. It only has a few words about custom tags. After fumbling for a long time, I finally imported the custom tags. My experience As follows:

1. Situation: Create a new custom tag library class: @.Mylib.Tag.TagLibTest — Those who understand TP should know the path represented by this

Use Tag demo file under Examples

<?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>
Copy after login

Then create a new taglibs.php file in the Conf directory under the project, content:

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

This way you can use it in the template:

<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>
Copy after login

This is a very simple situation, but my idea is to ask myself The defined tag library can be automatically imported, so there is no need to add tags like in the first line of each template.

It's just that this has encountered a little problem

2. Automatically import the custom tag library

Add in the config.php file:

&#39;TAGLIB_PRE_LOAD&#39; => &#39;article&#39; ,
Copy after login

Clear the cache, prompting the error "Instantiate a non-existent class!" ;

I searched around the TP official forum for a few times and found that there is only one way to solve it: import using aliases, that is, in the TP framework Add the import path under commonn/alias.php:

Such as:

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

There are also some solutions to modify the source code of the Template class, which are not easy to use - because usually I don’t want to worry about a small problem. Modify the core.

So I thought of the import of Action:

Add the import to your own project base class BaseAction.class.php:

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

Refresh cache, problem solved...

This solution is simple and easy to use.

Supplement:

Use TP’s automatic Loading configuration is faster:

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

Final solution:

1. Create Mylibs.Tag.TagLibTest — Custom Tag library

2. Configuration:

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

It can be used normally after deleting the cache.

The above is the entire content of this article. I hope it will be helpful to everyone's study. For more related content, please pay attention to the PHP Chinese website!

Related recommendations:

Introduction to the callback method of thinkPHP framework docking with Alipay’s instant payment interface

Commonly used systems in thinkphp Introduction to constants and system variables

ThinkPHP method of writing array insertion and obtaining the latest inserted data ID

The above is the detailed content of Introduction to the import method of thinkPHP2.1 custom tag library. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template