DEDECMS 정적 템플릿 클래스 파일이 무엇인가요?
정적 템플릿 클래스 파일 Dreamweaver 템플릿 엔진은 XML 네임스페이스 형식을 사용하는 템플릿 파서입니다.
추천 학습: Dreamweaver cms
Dreamweaver 파서를 사용하여 템플릿을 파싱할 때의 가장 큰 장점은 템플릿의 속성을 쉽게 설정할 수 있다는 것입니다. 태그는 HTML을 사용하는 것처럼 느껴지므로 템플릿 코드가 매우 직관적이고 유연해집니다. DreamWeaver 템플릿 엔진의 새 버전은 템플릿을 구문 분석할 수 있을 뿐만 아니라 템플릿에 있는 잘못된 태그도 분석할 수 있습니다.
include/dedetag.class.php 이 파일은 dedecms V5.3 및 이전 버전에서 사용되는 기본 템플릿 클래스입니다. 이는 컴파일된 템플릿 클래스가 아니라 분석 템플릿 클래스입니다(차이점은 전자가 후자는 직접 구문 분석된 PHP 코드이며 두 번 실행됩니다.)
1. 템플릿 구문
1 Dreamweaver 템플릿 엔진의 코드 스타일은 다음과 같은 형식을 갖습니다.
{dede: 태그 이름 속성 = ' value'/}
{dede:태그 이름 attribute='value'}{/dede:태그 이름}
{dede:태그 이름 attribute='value'}사용자 정의 스타일 템플릿(InnerText){/dede:태그 이름}
팁:
기본 템플릿과 함께 태그를 사용하는 경우 {dede:tag name attribute='value'}{/dede:tag name} 형식을 엄격히 사용해야 합니다. 그렇지 않으면 오류가 보고됩니다.
2. Dreamweaver 템플릿 엔진에는 여러 개의 시스템 태그가 내장되어 있으며 이러한 시스템 태그는 어떤 상황에서도 직접 사용할 수 있습니다.
(1) 전역 표시는 데이터베이스 비밀번호 외에도 시스템의 모든 구성 매개변수를 호출할 수 있음을 의미합니다. 형식은
{dede:global name='variable name'}입니다. {/dede:global}
또는
{dede:global name='variable name'/}
변수 이름은 $ 기호와 함께 추가할 수 없습니다(예: $cfg_cmspath 변수는 {dede로 작성해야 함). :전역 이름='cfg_cmspath'/}.
(2) foreach는 다음 형식으로 배열을 출력하는 데 사용됩니다.
{dede:foreach array='array name'}[field:key/] [field:value/]{/dede:foreach}
(3 ) include는 다음 형식으로 파일을 소개합니다.
{dede:include file='파일 이름' ismake='디데 템플릿인지 여부(예/아니요)'/}
파일 검색 경로는 다음과 같습니다. 순서: 절대 경로, 포함 폴더, CMS 설치 디렉토리, CMS 기본 템플릿 디렉토리
3. Dreamweaver 태그를 사용하면 모든 태그의 함수를 사용하여 다음 형식으로 얻은 값을 처리할 수 있습니다.
{dede: 태그 이름 속성 = 'value' function ='youfunction("Parameter 1","Parameter 2","@me")'/}
여기서 @me는 현재 태그의 값을 나타내는 데 사용되며 다른 매개변수는 함수에 따라 결정됩니다. 예를 들면 다음과 같습니다.
{dede:field name='pubdate' function='strftime("%Y-%m-%d %H:%M:%S","@me")'/}
4. Dreamweaver 마크는 제한된 프로그래밍 확장을 허용합니다.
형식은 다음과 같습니다.
코드는 다음과 같습니다.
{dede:tagname runphp='yes'} $aaa = @me; @me = "123456"; {/dede:tagname}
@me는 태그 자체의 값을 나타내기 때문에 인태그 프로그래밍에서는 echo와 같은 문을 사용할 수 없으며 모든 반환 값을 @에게만 전달할 수 있습니다. 나.
또한 프로그램 코드는 기본 템플릿 InnerText의 내용을 차지하므로 프로그래밍이 필요한 태그는 기본 InnerText만 사용할 수 있습니다.
2. Par Paring Method
dedetag.class.php에는 4 개의 클래스가 있습니다. 일반적으로 템플릿을 구문 분석할 때 다음 단계를 거칩니다.
$dtp = new DedeTagParse();
2. 템플릿/템플릿 문자열 로드:
$dtp->LoadTemplate(템플릿 파일) ); //캐시가 생성되며 두 번째로 템플릿을 구문 분석할 필요가 없습니다.
$dtp->LoadSource(string)
3. ($dtp-> CTags as $tid=>$ctag) {
//ctag의 이름과 속성을 결정하고 일반적으로 함수를 사용하여 다른 값을 할당합니다.
if($ctag->GetName=='mytag ') $ dtp->Assign($tid, mytagvalue($ctag) );
}
위의 예에서는 mytagvalue 함수로 직접 전달되어 $ctag의 각 속성을 판단합니다. 다른 값을 반환합니다.
버전 V5.3에서는 일반적으로 field 및 list와 같은 특수 태그 외에도 arc.*로 시작하는 클래스에 의해 구문 분석된 파일의 태그가 include/taglib의 소스 코드에 해당합니다. 이는 시스템에 의해 자동으로 수행됩니다. .
4. HTML로 표시 또는 저장
또는
$dtp->SaveTo(정적 파일 이름);
对于二次开发人员而言,不大需要知道dedecms模板具体解析方式,不过应该十分清楚CTag这个类的结构,从而判断标签不同属性进行处理。
代码如下:
class DedeTag { var $IsReplace=FALSE; //标记是否已被替代,供解析器使用 var $TagName=""; //标记名称 var $InnerText=""; //标记之间的文本 var $StartPos=0; //标记起始位置 var $EndPos=0; //标记结束位置 var $CAttribute=""; //标记属性描述,即是class DedeAttribute var $TagValue=""; //标记的值 var $TagID = 0; //获取标记的名称和值 function GetName() { return strtolower($this->TagName); } function GetValue() { return $this->TagValue; } //下面两个成员函数仅是为了兼容旧版 function GetTagName() { return strtolower($this->TagName); } function GetTagValue() { return $this->TagValue; } //获取标记的指定属性 function IsAttribute($str) { return $this->CAttribute->IsAttribute($str); } function GetAttribute($str) { return $this->CAttribute->GetAtt($str); } function GetAtt($str) { return $this->CAttribute->GetAtt($str); } function GetInnerText() { return $this->InnerText; } }
위 내용은 DEDECMS 정적 템플릿 클래스 파일이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!