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
Ce atribut face ca valoarea din caseta de text sa nu poata fi modificata de utilizator?
checked="checked" readonly="readonly" disabled="disabled"<input type="text" value="valoare-fixa" readonly="readonly" name="a_name" />
Ce proprietate CSS permite crearea de colturi rotunjite?
background-size border-size border-radius.class {
border:2px solid blue;
border-radius:1.2em;
}
Ce instructiune afiseaza o fereastra cu mesaj si butoane OK si Cancel?
indexOf() confirm() prompt()var ques = window.confirm("Rezultatul lui 0+0 este 0?");
if (ques) alert("Corect");
else alert("Incorect");
Indicati functia PHP care returneaza numarul cel mai mic dintr-o multime de numere.
floor() ceil() min()$min_nr = min(12, 8, 25, 13);
echo $min_nr; // 8
Alegeti verbul corect care trebuie in propozitia: "Its ears ... big".
are is hasIts ears are big.
- Urechile lui sunt mari.
Alegeti verbul corect care trebuie in propozitia: "Los niños ... deportistas"
soy son estáLos niños son deportistas.
- Copii sunt sportivi.