이 기사에서는 thinkPHP2.1 사용자 정의 태그 라이브러리 가져오기 방법을 자세히 설명합니다. 참고하실 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.
TP의 매뉴얼은 리듬을 따라갈 수 없는 것 같습니다. 커스텀 태그에 대한 몇 마디만 있습니다. 오랜 시간 고민 끝에 커스텀 태그를 가져온 제 생각은 다음과 같습니다.
1. 상황: 새 사용자 정의 태그 라이브러리 클래스 생성: @.Mylib.Tag.TagLibTest — TP를 이해하는 사람은 이것이 나타내는 경로를 알아야 합니다
예제 아래의 태그 데모 파일을 사용하세요
<?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('TagLib'); class TagLibArticle extends TagLib{ // 标签定义 protected $tags = array( // 标签定义: //attr 属性列表 close 是否闭合(0 或者1 默认1) alias 标签别名 level 嵌套层次 'article'=>array('attr'=>'name,field,limit,order,where,sql,key,mod','level'=>3), ); //定义查询数据库标签 public function _article($attr,$content) { $tag = $this->parseXmlAttr($attr,'article'); $result = !empty($tag['result'])?$tag['result']:'article'; //定义数据查询的结果存放变量 $key = !empty($tag['key'])?$tag['key']:'i'; $mod = isset($tag['mod'])?$tag['mod']:'2'; if ($tag['name']) { //根据用户输入的值拼接查询条件 $sql = "M('{$tag['name']}')->"; $sql .= ($tag['field'])?"field({$tag['field']})->":''; $sql .= ($tag['order'])?"order({$tag['order']})->":''; $sql .= ($tag['where'])?"where({$tag['where']})->":''; $sql .= "select()"; }else{ if (!$tag['sql']) return ''; //排除没有指定model名称,也没有指定sql语句的情况 $sql .= "M()->query('{$tag['sql']}')"; } //下面拼接输出语句 $parsestr = '<?php $_result='.$sql.'; if ($_result): $'.$key.'=0;'; $parsestr .= 'foreach($_result as $key=>$'.$result.'):'; $parsestr .= '++$'.$key.';$mod = ($'.$key.' % '.$mod.' );?>'; $parsestr .= $content;//解析在article标签中的内容 $parsestr .= '<?php endforeach; endif;?>'; return $parsestr; } } ?></liu21st>
그런 다음 프로젝트 아래의 Conf 디렉터리에 새 taglibs.php 파일을 만듭니다.
<?php return array( 'article'=>'@.TagLib.TagLibarticle', ); ?>
이 방법으로 템플릿에서 사용할 수 있습니다.
<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='stylesheet' type='text/css' href='__PUBLIC__/Css/common.css'> </head> <body> <div 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='3'> <hr> 示例源码<br/>控制器自定义标签类<br/> <php>highlight_file(LIB_PATH.'TagLib/TagLibarticle.class.php');</php></td> </tr> </table> </div> </body> </html>
이것은 매우 간단한 상황이지만, 내 생각은 사용자 정의 태그 라이브러리를 자동으로 가져오도록 요구하여 첫 번째 줄에
여기에 약간의 문제가 있습니다
2. 사용자 정의 태그 라이브러리 자동 가져오기
config.php 파일에
을 추가하세요.'TAGLIB_PRE_LOAD' => 'article' ,
캐시 지우기, "존재하지 않는 클래스를 인스턴스화하세요!"라는 오류 메시지 표시 ;
TP 공식 포럼을 몇 번 검색한 결과 해결 방법은 단 하나뿐이라는 것을 알았습니다. 별칭을 사용하여 가져오는 것, 즉 TP 프레임워크의 commonn/alias.php 아래에 가져오기 경로를 추가하는 것입니다.
예:
Template 클래스의 소스 코드를 수정하는 솔루션도 있지만 사용하기 쉽지 않습니다. 일반적으로 작은 문제로 인해 코어를 수정하고 싶지 않기 때문입니다.
그래서 Action을 임포트하려고 생각했습니다:
프로젝트 기본 클래스 BaseAction.class.php에 가져오기를 추가합니다.
function _initialize() { import("@.Mylibs.Tag.TagLibArticle"); }
캐시 새로고침으로 문제가 해결되었습니다...
이 솔루션은 간단하고 사용하기 쉽습니다.
보충:
TP의 자동 로딩 구성을 사용하면 더 빠릅니다.
'APP_AUTOLOAD_PATH'=> 'Think.Util.,@.Mylibs.Tag.',
최종 계획:
1. Mylibs.Tag.TagLibTest — 사용자 정의 태그 라이브러리 생성
2. 구성:
'APP_AUTOLOAD_PATH'=> 'Think.Util.,@.Mylibs.Tag.', 'TAGLIB_PRE_LOAD' => 'test' ,
캐시 삭제 후 정상적으로 이용 가능합니다.
더 많은 thinkPHP 관련 컨텐츠에 관심이 있는 독자는 이 사이트의 특별 주제인 "ThinkPHP 시작 튜토리얼", "ThinkPHP 템플릿 작동 기술 요약", "ThinkPHP 공통 메소드 요약", "Smarty 템플릿 기본 튜토리얼"을 확인할 수 있습니다. 및 "PHP 템플릿 기술 요약".
이 기사가 ThinkPHP 프레임워크를 기반으로 하는 모든 사람의 PHP 프로그래밍에 도움이 되기를 바랍니다.