PHP-Einfach.de
  • PHP Tutorial
  • MySQL Tutorial
  • Für Fortgeschrittene
  • Webhosting
  • Forum

Codeschnipsel

Meine Template klasse: Klein aber Oho

Zurück zur Übersicht
Das ist sie Meine Template Klasse:
<?php
/**
* @author Mogria <[email protected]>
* @version 0.2
*
*/

class mtpl {

    
/**
    *  Der Pfad zur Template Datei
    *  @var <string> $file
    */

    
private $file;

    
/**
    *  Enthält alle Variablen die ersetzt werden.
    *  Im Index befindet sich der Variabelnname
    *  und der dazugehörige Wert ist der Wert der Variable
    *  @var <array> $vars
    */
    
private $vars = Array();

    
/**
    * Konstrucktor
    * Hier wird geprüft ob die angegebene Datei existiert.
    * Wenn nicht wird eine Fehlermeldung ausgegeben.
    * @param <string> $file der Pfad zur Templatedatei
    */
    
public function __construct ($file) {
        if( 
is_file ($file) ) {
            
$this->file = $file;
        } else {
            die ( 
"<strong>FEHLER: </strong>Die angebene Template-Datei \"$file\" existiert nicht!");
        }
    }

    
/**
    * Hier werden Variablen gesammelt die später im Template File eingesetzt werden
    * @param <string> $var Name der Variable
    * @param <string> $value Inhalt der Variable
    */
    
public function setvar($var, $value) {
        
$this->vars[$var] = $value;
    }

    
/**
    * Gibt die angegebene Variable zurück die mit setvar() definiert hat.
    * Falls sie nicht existiert wird false zurückgegeben.
    *
    * @param <string> Variablenname
    * @return <mixed> inhalt der Variable on success, <bool> false on failure.
    */
    
public function getvar($var) {
        if (
$this->varexists($var)) {
            return 
$var;
        } else {
            return 
false;
        }
    }

    
/**
    * Prüft ob eine Variable bereits mit setvar gesetzt wurde
    *
    * @param <string> Variabelnname
    * @return <bool> true on success, false on failure
    */
    
public function varexists($var) {
        return isset(
$this->vars[$var]);
    }

    
/**
    * Hier kann man mehrere Variabeln auf einmal angeben.
    * Im index den Variablenamen und der dazugehörige wert ist der Inhalt der Variable
    *
    * @param <array> $array
    */
    
public function array_setvar($array) {
        
$keys = array_keys($array);
        
$value = array_values($array);
        foreach( 
$keys as $k => $key){
            if(!
ctype_digit($key))
                
$this->setvar($key, $value[$k]);
        }
    }

    
/**
    * Der Inhalt der Template Datei wird umgeformt, damit es eval ausführen kann.
    * @return <string> Der geparste inhalt von der Datei dessen Pfad in der Eigenschaft $file festgelegt ist
    */
    
private function parse() {
         
//Die Template Datei wird ausgelesen
         
$var = file_get_contents($this->file);
         
//alle " werden escaped
         
$var = str_replace('"','\\"', $var);
         
$var = str_replace( '?}', ' echo "', str_replace('{?', '"; ', $var ));
         
$var = str_replace( '.}', ' . "', str_replace('{.', '" . ', $var ));
         
$var = preg_replace_callback('`"; (.*?) echo "`si', create_function( '$treffer', 'return str_replace(\'\\"\', \'"\',$treffer[0]);') , $var);
         
$var = preg_replace_callback('`" \. (.*?) \. "`si', create_function( '$treffer', 'return str_replace(\'\\"\', \'"\',$treffer[0]);') , $var);
         return 
$var;
    }

    
/**
    * Gibt den Geparsten Inhalt der Template Datei aus
    * @return <string>
    */
    
public function output() {
        
//Die Ausgabe wird angehalten
        
ob_start();
        
//Alle Variablen werden extrahiert
        
extract($this->vars, EXTR_SKIP);
        
//Die Ausgabe wird kommt in den Ausgabepuffer
        
eval('echo "' . $this->parse() . '";');
        
//Der Ausgabepuffer wird der variable ausgabe zugewiesen
        
$ausgabe = ob_get_contents();
        
//Der Ausgabepuffer wird geleert
        
ob_end_clean();
        
//Der Inhalt des Ausgabepuffers wird zurückgegeben
        
return $ausgabe;
    }
}

?>


Da ihr jetzt sehrwahrscheindlich eh nur drübergeflogen seid, und nicht wisst um was es geht, mach ich euch ein Anwendungs Beispiel.

Das ist unsere Template Datei 'test.tpl':
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>$titel</title>
</head>
<body>
    <h1>$heading</h1>
    <p>$text</p>
    <table border="1" cellpadding="2">
        {? foreach($chars as $k => $char) { ?}
        <tr>
            <td>{. ($k + 1 ) .}</td>
            <td>{. $char .}</td>
        </tr>
        {? } ?}
    </table>
    <p>Heute ist der {. date('d.m') .} im Jahre {. date("Y") .}</p>
</body>
</html>


Und das ist unsere php Datei 'test.php':
<?php
//Die Klasse wird eingebunden
require_once("mtpl.class.php");
//Das Objekt wird erstellt
$tpl = new mtpl("test.tpl");

//Drei Variabeln werden auf einmal gesetzt
$tpl->array_setvar(
    Array(
        
'titel' => "Alphabet",
        
'heading' => "Die Buchstaben des Alphabet's",
        
'text' => "Hier sehen sie Alle 26 Buchstaben des Alphabets"
    
)
);

//Es werden alle Buchstaben des Alphabets geholt
$buchstaben = Array();
for(
$i = 0; $i<26; $i++){
    
$buchstaben[] = chr($i + 97);
}

//Die Variable "chars" wird gesetzt
$tpl->setvar('chars', $buchstaben);
//Das Template Wird geparst & ausgegeben
echo $tpl->output();

?>


Und das ist der Quellcode der in den Browser kommt:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>Alphabet</title>
</head>
<body>
    <h1>Die Buchstaben des Alphabet's</h1>
    <p>Hier sehen sie Alle 26 Buchstaben des Alphabets</p>
    <table border="1" cellpadding="2">
        
        <tr>
            <td>1</td>
            <td>a</td>                
        </tr>
        
        <tr>
            <td>2</td>
            <td>b</td>                
        </tr>
        
        <tr>
            <td>3</td>
            <td>c</td>                
        </tr>
        
        <tr>
            <td>4</td>
            <td>d</td>                
        </tr>
        
        <tr>
            <td>5</td>
            <td>e</td>                
        </tr>
        
        <tr>
            <td>6</td>
            <td>f</td>                
        </tr>
        
        <tr>
            <td>7</td>
            <td>g</td>                
        </tr>
        
        <tr>
            <td>8</td>
            <td>h</td>                
        </tr>
        
        <tr>
            <td>9</td>
            <td>i</td>                
        </tr>
        
        <tr>
            <td>10</td>
            <td>j</td>                
        </tr>
        
        <tr>
            <td>11</td>
            <td>k</td>                
        </tr>
        
        <tr>
            <td>12</td>
            <td>l</td>                
        </tr>
        
        <tr>
            <td>13</td>
            <td>m</td>                
        </tr>
        
        <tr>
            <td>14</td>
            <td>n</td>                
        </tr>
        
        <tr>
            <td>15</td>
            <td>o</td>                
        </tr>
        
        <tr>
            <td>16</td>
            <td>p</td>                
        </tr>
        
        <tr>
            <td>17</td>
            <td>q</td>                
        </tr>
        
        <tr>
            <td>18</td>
            <td>r</td>                
        </tr>
        
        <tr>
            <td>19</td>
            <td>s</td>                
        </tr>
        
        <tr>
            <td>20</td>
            <td>t</td>                
        </tr>
        
        <tr>
            <td>21</td>
            <td>u</td>                
        </tr>
        
        <tr>
            <td>22</td>
            <td>v</td>                
        </tr>
        
        <tr>
            <td>23</td>
            <td>w</td>                
        </tr>
        
        <tr>
            <td>24</td>
            <td>x</td>                
        </tr>
        
        <tr>
            <td>25</td>
            <td>y</td>                
        </tr>
        
        <tr>
            <td>26</td>
            <td>z</td>                
        </tr>
        
    </table>
    <p>Heute ist der 26.07 im Jahre 2010</p>
</body>
</html>


Erklärung des Output Vorgangs: In der Funktion output() wird die Ausgabepufferung aktiviert. Alles was jetzt Ausgegeben wird z.B. mit echo, kommt in den Ausgabepuffer. Nun werden alle Variabeln die Vorher gesetzt wurden extrahiert. d.h. ein $array['index'] = "inhalt" wird zu $index = "inhalt".

Danach wird die Parse Funktion aufgerufen, und die Am anfang angegebene Datei wird ausgelesen. Es werden alle " escaped & alle {. werden zu " . , .} wird zu . " , {? wird zu "; , ?} wird zu echo " . Mit den 2 preg_replace_callback werden die slashes vor " entfernt die sich in einen von den bereichen {? ?} oder {. .} befinden, damit keine Fehler aufstreten, wenn man darin strings schreibt mit dem Double Qout.

Das Ergebnis wird zurückgegeben und per eval & echo ausgegeben, damit die Variablen die wir aus den Array geholt haben ihre Wirkung nehmen.
Eval führt Folgenden PHP code aus:
<?
echo "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\"
    \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">
<html xmlns=\"http://www.w3.org/1999/xhtml\">
<head>
  <title>$titel</title>
</head>
<body>
    <h1>$heading</h1>
    <p>$text</p>
    <table border=\"1\" cellpadding=\"2\">
        ";  foreach($chars as $k => $char) {  echo "
        <tr>
            <td>" .  ($k + 1 )  . "</td>
            <td>" .  $char  . "</td>                
        </tr>
        ";  }  echo "
    </table>
    <p>Heute ist der " .  date('d.m')  . " im Jahre " .  date("Y")  . "</p>
</body>
</html>";


Das ganze geht so in den Ausgabepuffer. Der Ausgabepuffer wird der Variable $ausgabe zugewiesen. Der Ausgabepuffer wird geleert, und die Ausgabepufferung wird abgeschalten.
$ausgabe wird zurückgegeben. Und schliesslich dann in test.php mit echo ausgegeben...

mfg
Mogria


Kommentare

Autor Mogria

Zurück zur Übersicht
Autor: Nils Reimers
Zurück: URLs im Text identifizieren

Für Fortgeschrittene

  • Objektorientierte Programmierung
  • PHP Sicherheit
  • Script-Beispiele
  • Codeschnipsel
  • Stellenmarkt
Mit freundlicher Unterstützung von:
  • Punkt191 Werbeagentur
  • CasinoAndy Finland
  • Casinoohnelizenz.info
  • Cryptocasinomaster.com
  • CasinoHEX.at
  • inkedin.com

Hoster – Geringste Ausfallzeit

  1. webgo Ø 1 Min.
  2. Linevast Ø 2 Min.
  3. netcup Ø 3 Min.
  4. All-Inkl.com Ø 6 Min.
  5. checkdomain Ø 8 Min.
  6. dogado Ø 17 Min.
  7. bplaced Ø 17 Min.
  8. Contabo Ø 25 Min.
  9. Hetzner Ø 49 Min.
  10. ONE.com Ø 62 Min.
» Mehr erfahren

Impressum | Datenschutz | Auf PHP-Einfach.de werben

© PHP-Einfach.de 2003 - 2023

Cookie-Zustimmung verwalten
Um dir ein optimales Erlebnis zu bieten, verwenden wir Technologien wie Cookies, um Geräteinformationen zu speichern und/oder darauf zuzugreifen. Wenn du diesen Technologien zustimmst, können wir Daten wie das Surfverhalten oder eindeutige IDs auf dieser Website verarbeiten. Wenn du deine Zustimmung nicht erteilst oder zurückziehst, können bestimmte Merkmale und Funktionen beeinträchtigt werden.
Funktional Immer aktiv
Die technische Speicherung oder der Zugang ist unbedingt erforderlich für den rechtmäßigen Zweck, die Nutzung eines bestimmten Dienstes zu ermöglichen, der vom Teilnehmer oder Nutzer ausdrücklich gewünscht wird, oder für den alleinigen Zweck, die Übertragung einer Nachricht über ein elektronisches Kommunikationsnetz durchzuführen.
Vorlieben
Die technische Speicherung oder der Zugriff ist für den rechtmäßigen Zweck der Speicherung von Präferenzen erforderlich, die nicht vom Abonnenten oder Benutzer angefordert wurden.
Statistiken
Die technische Speicherung oder der Zugriff, der ausschließlich zu statistischen Zwecken erfolgt. Die technische Speicherung oder der Zugriff, der ausschließlich zu anonymen statistischen Zwecken verwendet wird. Ohne eine Vorladung, die freiwillige Zustimmung deines Internetdienstanbieters oder zusätzliche Aufzeichnungen von Dritten können die zu diesem Zweck gespeicherten oder abgerufenen Informationen allein in der Regel nicht dazu verwendet werden, dich zu identifizieren.
Marketing
Die technische Speicherung oder der Zugriff ist erforderlich, um Nutzerprofile zu erstellen, um Werbung zu versenden oder um den Nutzer auf einer Website oder über mehrere Websites hinweg zu ähnlichen Marketingzwecken zu verfolgen.
Optionen verwalten Dienste verwalten Anbieter verwalten Lese mehr über diese Zwecke
Einstellungen ansehen
{title} {title} {title}