Acest tutorial arata cum puteti
crea o simpla pagina (fisier) template care sa fie utilizat pentru pagini web in PHP.
Vom folosi doua fisiere: "
index.php" cu scriptul PHP in care sunt definite datele ce vor fi adaugate in pagina, si "
page.tpl" care contine template-ul, cod HTML cu expresii ce vor fi inlocuite cu date definite in "index.php".
Expresia adaugata in template, in codul HTML, are aceasta forma (
un comentariu HTML):
<!-- CUVANT -->
- Aceasta expresie nu e afisata in pagina daca nu setati in PHP o valoare care sa o inlocuiasca, deoarece e tratata ca un comentariu HTML.
Codul pt. template, adaugat in "page.tpl" (cu HTML5)
<!doctype html>
<html>
<head>
<meta charset="utf-8" />
<title><!-- TITLE --></title>
<meta name="description" content="<!-- META_DESCRIPTION -->" />
<meta name="keywords" content="<!-- META_KEYWORDS -->" />
<style>header, footer, section, aside, nav, article {display: block;}</style>
<!--[if IE]><script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script><![endif]-->
</head>
<body>
<header id="header">
<h1><!-- TITLE --></h1>
</header>
<section id="article">
<!-- ARTICLE -->
</section>
<section id="sidemenu">
<nav><!-- SIDEMENU --></nav>
</section>
<footer id="footer">
<!-- FOOTER -->
</footer>
</body>
</html>
Codul pentru "index.php" (explicatiile sunt in comentariu din cod)
<?php
// array cu chei /cuvinte care sunt adaugate in template (in comentariu HTML)
// aceste elemente (initial fara valoare) vor contine date care vor inlocui comentariu HTML din template
$templ = array('TITLE'=>'', 'META_DESCRIPTION'=>'', 'META_KEYWORDS'=>'', 'ARTICLE'=>'', 'SIDEMENU'=>'', 'FOOTER'=>'');
// preia cheile din $templ ca sa fie adaugate in RegExp
$templ_k = array_keys($templ);
// Sablon /Tipar RegExp cu expresia folosita in template
$templ_rgx = '/<!-- ('.implode('|', $templ_k).') -->/i';
// setare /definire date in elementele din $templ, care vor inlocui comentariu corespunzator in template
// aceste date pot fi preluate dintr-o baza de date, fisier extern, array, etc.
$templ['TITLE'] = 'Cursuri gratuite: marplo.net';
$templ['META_DESCRIPTION'] = 'Descriere adaugata in meta tag';
$templ['META_KEYWORDS'] = 'Cuvinte, importante, din pagina';
$templ['ARTICLE'] = 'Articol, continut adaugat in corpul paginii';
$templ['SIDEMENU'] = 'Meniu: <ul><li><a href="https://marplo.net/" title="Cursuri gratuite">Cursuri gratuite</a></li></ul>';
$templ['FOOTER'] = 'Continut adaugat in subsolul paginii';
// preia template-ul
$tpl = file_get_contents('page.tpl');
// inlocuieste datele in template si afiseaza pagina obtinuta
echo preg_replace_callback($templ_rgx, function($m) { GLOBAL $templ; return $templ[$m[1]]; }, $tpl);
?>
Expresia:
$templ_rgx = '/<!-- ('.implode('|', $templ_k).') -->/i';
Creaza sablonul RegExp cu, cuvintele folosite in modelul din template ce va fi inlocuit cu date din PHP, aceste cuvinte sunt cheile adaugate in array-ul
$templ. Sunt adaugate in RegExp separate prin "|" ca sa creeze un sablon ca acesta:
/<!-- (CUVANT_1|CUVANT_2|CUVANT_3) -->/i
- Aceasta Expresie Regulata se va potrivi doar cu modelul (comentariul HTML) din template format cu cheile /cuvintele adaugate in $templ, astfel, alte comentarii HTML nu vor fi luate in considerare.
- Extensia "/i" determina functia preg_replace_callback() sa evalueze expresia indiferent de majuscule sau litere mici.
- Prin adaugarea cuvintelor pentru template in array ca elemente cu valoare vida, se evita erorile in cazul in care nu sunt definite date pentru acel element, si va adauga valoarea vida in codul HTML.
Un Test simplu in fiecare zi
HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Care tag HTML5 defineste un text marcat, evidentiat?
<mark> <embed> <span><p>Cursuri graruite: <mark>MarPlo.net</mark> , jocuri, anime.</p>
Ce pseudo-clasa CSS defineste un stil la element cand mouse-ul e deasupra lui?
:focus :hover :activea:hover {
font-weight: bold;
color: #00da01;
}
Clic pe functia ce returneaza un sir cu un numar rotunjit la x decimale.
toPrecision(x) toFixed(x) floor(x)var num = 12.34567;
num = num.toFixed(2);
alert(num); // 12.35
Indicati functia PHP care adauga continutul unui fisier intr-un array.
[) file() readfile()$arr = file("a_file.txt", FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
var_export($arr);
Clic pe raspunsul potrivit la intrebarea: "What time is it?"
On the 7th of July 1996 It is a quarter to 5. Nice weather.What time is it? It is a quarter to 5.
- Cat este ora? E 5 fara un sfert.
Indicati raspunsul potrivit la intrebarea: "¿Qué hora es?"
Hace buen tiempo. En el 7 de julio de 1996 Son las tres menos cuarto.¿Qué hora es? Son las tres menos cuarto.
- Cat este ora? E 3 fara un sfert.