Ich habe den Quellcode von phpcms und discuz gesehen, daher mangelt es möglicherweise an Innovation. Die Prinzipien sind jedoch größtenteils gleich, die Details können jedoch geringfügig abweichen.
Kommen wir zum Punkt, beginnen wir mit dem Gespräch über den konkreten Umsetzungsprozess.
1. Zunächst müssen Sie darüber nachdenken, wo Sie die Vorlagendatei ablegen möchten. Wohin mit den konvertierten PHP-Dateien? Und wie soll man es benennen? Gehen Sie direkt zum Quellcode:
Kopieren Sie den Code. Der Code lautet wie folgt:
function template($tpl = 'index',$dir = 'hello')
{
if(!file_exists ($pd = TPL_PATH.$ dir.'/'))@mkdir($pd,0777) or die("$pd-Verzeichniserstellung fehlgeschlagen");//wie z. B. Cache/tpl/hello/
if(! file_exists($td = TPL.$ dir.'/'))@mkdir($td,0777) or die("$td Verzeichniserstellung fehlgeschlagen");//wie data/tpl/hello/
$t2p = $pd.$tpl .'.php';//Die PHP-Datei, die nach der regulären Konvertierung der Vorlagendatei erstellt wird, z. B. Cache/tpl/hello/index.php
$t2h = $td.$ tpl.'.html';//html-Vorlagendatei, z. B. data/tpl/hello/index.html
2. Wann ist eine regelmäßige Konvertierung erforderlich? Es kann sein, dass die PHP-Datei nach der Regularisierung nicht existiert oder dass sich die HTML-Datei vor der Regularisierung geändert hat. Hier wird die Funktion filemtime(string $path) verwendet, die den Zeitpunkt der letzten Änderung der Datei zurückgibt.
Code kopieren Der Code lautet wie folgt:
if(!file_exists($t2p) || @filemtime($t2p) < @filemtime($t2h) )//Nachdem die Vorlagendatei geändert wurde, wird die reguläre PHP-Datei wird entsprechend aktualisiert
{
template_go($t2p,$t2h);//Vorlagenkonvertierung beginnt
}
return $t2p;//Zurück zur regulierten PHP-Datei, die sein kann so aufgerufen: include template('header ','hello');
}
3. Starten Sie die Vorlagenkonvertierung, lesen Sie sie zuerst aus der HTML-Datei, ersetzen Sie sie dann durch reguläre Ausdrücke und schreiben Sie sie schließlich in die PHP-Datei.
Code kopieren Der Code lautet wie folgt:
function template_go($t2p,$t2h)
{
$str = @file_get_contents($t2h);//Auslesen
if($ str == = false) exit("Die Vorlagendatei fehlt, bitte überprüfen!");
$str = template_do($str);//Reguläre Ersetzung
@chmod($t2p,0777); 🎜>return $str = file_put_contents($t2p, $str);//Write
}
4. Reguläre Regeln, mehrere relativ einfache reguläre Ersetzungssyntax.
Code kopieren Der Code lautet wie folgt:
function template_do($str)
{
$str = preg_replace('/([nr+])t+/s', '\1', $ str); // TAB-Tabulatorzeichen entfernen. Der Modifikator /s ignoriert keine Zeilenumbrüche
$str = preg_replace('/{$(.*)}/Us', '', $str);/* {$xx} wird durch ersetzt. Beachten Sie, dass der Modifikator /U hinzugefügt werden muss und nur einmal übereinstimmen kann. Sie können auch Lazy Matching verwenden */
$str = preg_replace('/{php (.+)}/', '', $str);/*{php xxxx} Beachten Sie, dass Sie den Modifikator /s nicht hinzufügen können. Sie müssen das Problem von Zeilenumbrüchen berücksichtigen, wenn Sie diese reguläre Regel mehrmals ausführen*/
$str = preg_replace('/{template(.* )}/Us ', '',
/*{template(xx,yy)} ersetzt durch $str = preg_replace('/{include (.*)}/Us', '', $str);/* {include xx. php} ersetzt durch ".$str ;
//$str = preg_replace('/s+/', ' ', $str);//Überprüfen Sie den Quellcode der Webseite, um zu sehen,
return $str;
}
Natürlich ist diese Funktion noch relativ rudimentär und ich hoffe, dass sie verbessert werden kann.