Výukový program PHP

PHP HOME Úvod do PHP Instalace PHP Syntaxe PHP Komentáře PHP PHP proměnné PHP Echo / tisk Datové typy PHP PHP řetězce PHP čísla PHP matematika Konstanty PHP Operátoři PHP PHP If...Else...Elseif Přepínač PHP PHP smyčky Funkce PHP Pole PHP PHP Superglobals PHP RegEx

Formuláře PHP

Manipulace s formuláři PHP Ověření formuláře PHP Je vyžadován formulář PHP Adresa URL / e-mail PHP formuláře Formulář PHP dokončen

PHP pro pokročilé

Datum a čas PHP Zahrnout PHP Práce se soubory PHP PHP soubor otevřít/číst Vytvoření/zápis souboru PHP Nahrání souboru PHP PHP soubory cookie PHP relace PHP filtry Pokročilé filtry PHP Funkce zpětného volání PHP PHP JSON Výjimky PHP

PHP OOP

PHP Co je OOP PHP třídy/objekty PHP konstruktor PHP destruktor Modifikátory přístupu PHP Dědičnost PHP Konstanty PHP Abstraktní třídy PHP Rozhraní PHP Vlastnosti PHP Statické metody PHP Statické vlastnosti PHP Jmenné prostory PHP PHP Iterables

Databáze MySQL

Databáze MySQL Připojení MySQL MySQL Vytvořte DB Vytvořit tabulku MySQL Vložit data MySQL MySQL Get Last ID MySQL Insert Multiple MySQL připraveno MySQL Select Data Kde MySQL Pořadí MySQL podle Vymazání dat MySQL Aktualizace dat MySQL Limit dat MySQL

PHP XML

PHP analyzátory XML PHP SimpleXML Parser PHP SimpleXML - Získejte PHP XML expat PHP XML DOM

PHP - AJAX

Úvod do AJAXu AJAX PHP Databáze AJAX AJAX XML AJAX Live Search Anketa AJAX

Příklady PHP

Příklady PHP PHP kompilátor PHP kvíz Cvičení PHP Certifikát PHP

Reference PHP

Přehled PHP Pole PHP Kalendář PHP Datum PHP Adresář PHP Chyba PHP Výjimka PHP Souborový systém PHP PHP filtr PHP FTP PHP JSON Klíčová slova PHP PHP Libxml PHP Mail PHP matematika PHP Různé PHP MySQLi Síť PHP Ovládání výstupu PHP PHP RegEx PHP SimpleXML PHP stream PHP řetězec PHP Variable Handling PHP XML Parser PHP zip Časová pásma PHP

Příklad PHP – AJAX Live Search


AJAX lze použít k vytvoření uživatelsky přívětivějšího a interaktivnějšího vyhledávání.


AJAX Live Search

Následující příklad bude demonstrovat živé vyhledávání, kde během psaní získáváte výsledky vyhledávání.

Živé vyhledávání má ve srovnání s tradičním vyhledáváním mnoho výhod:

  • Výsledky se zobrazují během psaní
  • Při dalším psaní se výsledky zužují
  • Pokud jsou výsledky příliš úzké, odeberte znaky, abyste viděli širší výsledek

Ve vstupním poli níže vyhledejte stránku W3Schools:

Výsledky ve výše uvedeném příkladu se nacházejí v souboru XML ( links.xml ). Aby byl tento příklad malý a jednoduchý, je k dispozici pouze šest výsledků.


Vysvětlený příklad - Stránka HTML

Když uživatel zadá znak do vstupního pole výše, spustí se funkce "showResult()". Funkce je spuštěna událostí "onkeyup":

<html>
<head>
<script>
function showResult(str) {
  if (str.length==0) {
    document.getElementById("livesearch").innerHTML="";
    document.getElementById("livesearch").style.border="0px";
    return;
  }
  var xmlhttp=new XMLHttpRequest();
  xmlhttp.onreadystatechange=function() {
    if (this.readyState==4 && this.status==200) {
      document.getElementById("livesearch").innerHTML=this.responseText;
      document.getElementById("livesearch").style.border="1px solid #A5ACB2";
    }
  }
  xmlhttp.open("GET","livesearch.php?q="+str,true);
  xmlhttp.send();
}
</script>
</head>
<body>

<form>
<input type="text" size="30" onkeyup="showResult(this.value)">
<div id="livesearch"></div>
</form>

</body>
</html>

Vysvětlení zdrojového kódu:

Pokud je vstupní pole prázdné (str.length==0), funkce vymaže obsah zástupného symbolu živého vyhledávání a ukončí funkci.

Pokud vstupní pole není prázdné, funkce showResult() provede následující:

  • Vytvořte objekt XMLHttpRequest
  • Vytvořte funkci, která se má provést, až bude odpověď serveru připravena
  • Odešlete požadavek do souboru na serveru
  • Všimněte si, že k adrese URL je přidán parametr (q) (s obsahem vstupního pole)


Soubor PHP

Stránka na serveru vyvolaná výše uvedeným JavaScriptem je soubor PHP s názvem „livesearch.php“.

Zdrojový kód v "livesearch.php" hledá v souboru XML názvy odpovídající hledanému řetězci a vrací výsledek:

<?php
$xmlDoc=new DOMDocument();
$xmlDoc->load("links.xml");

$x=$xmlDoc->getElementsByTagName('link');

//get the q parameter from URL
$q=$_GET["q"];

//lookup all links from the xml file if length of q>0
if (strlen($q)>0) {
  $hint="";
  for($i=0; $i<($x->length); $i++) {
    $y=$x->item($i)->getElementsByTagName('title');
    $z=$x->item($i)->getElementsByTagName('url');
    if ($y->item(0)->nodeType==1) {
      //find a link matching the search text
      if (stristr($y->item(0)->childNodes->item(0)->nodeValue,$q)) {
        if ($hint=="") {
          $hint="<a href='" .
          $z->item(0)->childNodes->item(0)->nodeValue .
          "' target='_blank'>" .
          $y->item(0)->childNodes->item(0)->nodeValue . "</a>";
        } else {
          $hint=$hint . "<br /><a href='" .
          $z->item(0)->childNodes->item(0)->nodeValue .
          "' target='_blank'>" .
          $y->item(0)->childNodes->item(0)->nodeValue . "</a>";
        }
      }
    }
  }
}

// Set output to "no suggestion" if no hint was found
// or to the correct values
if ($hint=="") {
  $response="no suggestion";
} else {
  $response=$hint;
}

//output the response
echo $response;
?>

Pokud je z JavaScriptu odeslán nějaký text (strlen($q) > 0), stane se následující:

  • Načtěte soubor XML do nového objektu XML DOM
  • Procházejte všechny prvky <title> a vyhledejte shodu z textu odeslaného z JavaScriptu
  • Nastaví správnou adresu URL a název v proměnné „$response“. Pokud je nalezeno více než jedna shoda, jsou do proměnné přidány všechny shody
  • Nejsou-li nalezeny žádné shody, proměnná $response je nastavena na "žádný návrh"