Curs Php-mysql

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 afiseaza textul oblic?
<strong> <pre> <em>
<p>Cursuri, Jocuri, Anime: <em>www.MarPlo.net</em></p>
Care proprietate CSS defineste spatiul dintre continutul elementului si bordura lui?
margin padding position
h3 {
  padding: 2px 0.2em;
}
Clic pe metoda ce returneaza primul element indicat de selectorii specificati.
getElementsByName() querySelector() querySelectorAll()
// preia primul Div cu class="cls", si afiseaza continutul
var elm = document.querySelector("div.cls");
alert(elm.innerHTML);
Indicati variabila PHP ce contine datele din formular trimise cu method="post".
$_SESSION $_GET $_POST
if(isset($_POST["field"])) {
  echo $_POST["field"];
}
Indicati pronumele corespunzator celui din paranteza in propozitia: "(Noi) speak english".
I They We
We speak english.
- Noi vorbim engleza.
Indicati pronumele corespunzator celui din paranteza in propozitia: "(Noi) hablamos español".
Ellos Vosotros Nosotros
Nosotros hablamos español.
- Noi vorbim spaniola.
Creare si utilizare Pagina Template

Last accessed pages

  1. Lectii audio-video de limba engleza (23929)
  2. Prezentul simplu si continuu - Present Tense Simple and Continuous (145360)
  3. Obtine Atibutul ID, Class, Name, Title, Src cu jQuery (276)
  4. Programe si scripturi pentru webmasters (5174)
  5. Colorare text (806)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (931)
  2. Curs HTML gratuit Tutoriale HTML5 (751)
  3. Coduri pt culori (575)
  4. Creare si editare pagini HTML (448)
  5. Conditional IF in Limba Engleza - Fraze Conditionale (431)
Chat
Discuta sau lasa un mesaj pt. ceilalti utilizatori
Full screenInchide