Samouczek PHP

Strona główna PHP Wprowadzenie do PHP Instalacja PHP Składnia PHP Komentarze PHP Zmienne PHP PHP Echo / Drukuj Typy danych PHP Ciągi PHP Liczby PHP Matematyka w PHP Stałe PHP Operatory PHP PHP Jeśli...Inne...Elseif Przełącznik PHP Pętle PHP Funkcje PHP Tablice PHP PHP Superglobals PHP RegEx

Formularze PHP

Obsługa formularzy PHP Walidacja formularzy PHP Wymagany formularz PHP Adres URL/e-mail formularza PHP Formularz PHP kompletny

Zaawansowany PHP

Data i godzina w PHP Uwzględnij PHP Obsługa plików PHP Otwórz/odczytaj plik PHP Tworzenie/zapisywanie plików PHP Przesyłanie plików PHP Pliki cookie PHP Sesje PHP Filtry PHP Zaawansowane filtry PHP Funkcje wywołania zwrotnego PHP PHP JSON Wyjątki PHP

PHP OOP

PHP Co to jest OOP Klasy/obiekty PHP Konstruktor PHP Destruktor PHP Modyfikatory dostępu PHP Dziedziczenie PHP Stałe PHP Klasy abstrakcyjne PHP Interfejsy PHP Cechy PHP Metody statyczne PHP Właściwości statyczne PHP Przestrzenie nazw PHP Iterowalne PHP

Baza danych MySQL

Baza danych MySQL Połączenie MySQL Tworzenie bazy danych MySQL Utwórz tabelę MySQL Wstaw dane MySQL Pobierz ostatni identyfikator MySQL Wstaw wiele MySQL Przygotowano MySQL Wybierz dane MySQL MySQL Gdzie Zamów MySQL według Usuń dane MySQL Dane aktualizacji MySQL Dane limitu MySQL

PHP XML

Parsery PHP XML Parser PHP SimpleXML PHP SimpleXML — Get Rozszerzenie PHP XML PHP XML DOM

PHP - AJAX

Wprowadzenie do AJAX AJAX PHP Baza danych AJAX XML AJAX Wyszukiwanie na żywo AJAX Ankieta AJAX

Przykłady PHP

Przykłady PHP Kompilator PHP Quiz PHP Ćwiczenia PHP Certyfikat PHP

Odniesienie do PHP

Przegląd PHP Tablica PHP Kalendarz PHP Data PHP Katalog PHP Błąd PHP Wyjątek PHP System plików PHP Filtr PHP PHP FTP PHP JSON Słowa kluczowe PHP Biblioteka PHP Poczta PHP Matematyka w PHP Różne PHP PHP MySQLi Sieć PHP Kontrola wyjścia PHP PHP RegEx PHP SimpleXML Strumień PHP ciąg PHP Obsługa zmiennych PHP Parser PHP XML Kod pocztowy PHP Strefy czasowe PHP

Przykład PHP — AJAX Live Search


AJAX może być używany do tworzenia bardziej przyjaznych dla użytkownika i interaktywnych wyszukiwań.


Wyszukiwanie na żywo AJAX

Poniższy przykład zademonstruje wyszukiwanie na żywo, w którym otrzymujesz wyniki wyszukiwania podczas pisania.

Wyszukiwanie na żywo ma wiele zalet w porównaniu z tradycyjnym wyszukiwaniem:

  • Wyniki są wyświetlane podczas pisania
  • Wyniki zawężają się, gdy kontynuujesz pisanie
  • Jeśli wyniki stają się zbyt wąskie, usuń znaki, aby zobaczyć szerszy wynik

Wyszukaj stronę W3Schools w polu wejściowym poniżej:

Wyniki w powyższym przykładzie znajdują się w pliku XML ( links.xml ). Aby ten przykład był mały i prosty, dostępnych jest tylko sześć wyników.


Objaśnienie przykładu — strona HTML

Gdy użytkownik wpisze znak w powyższym polu wejściowym, wykonywana jest funkcja "showResult()". Funkcja jest wyzwalana przez zdarzenie „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>

Wyjaśnienie kodu źródłowego:

Jeśli pole wejściowe jest puste (str.length==0), funkcja czyści zawartość obiektu zastępczego livesearch i wychodzi z funkcji.

Jeśli pole wejściowe nie jest puste, funkcja showResult() wykonuje następujące czynności:

  • Utwórz obiekt XMLHttpRequest
  • Utwórz funkcję do wykonania, gdy odpowiedź serwera będzie gotowa
  • Wyślij żądanie do pliku na serwerze
  • Zauważ, że parametr (q) jest dodawany do adresu URL (z zawartością pola wejściowego)


Plik PHP

Strona na serwerze wywoływana przez powyższy JavaScript to plik PHP o nazwie "livesearch.php".

Kod źródłowy w "livesearch.php" przeszukuje plik XML w poszukiwaniu tytułów pasujących do szukanego ciągu i zwraca wynik:

<?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;
?>

Jeśli jakiś tekst zostanie wysłany z JavaScript (strlen($q) > 0), dzieje się co następuje:

  • Załaduj plik XML do nowego obiektu XML DOM
  • Przeprowadź pętlę przez wszystkie elementy <title>, aby znaleźć dopasowania z tekstu wysłanego z JavaScript
  • Ustawia poprawny adres URL i tytuł w zmiennej „$response”. W przypadku znalezienia więcej niż jednego dopasowania, wszystkie dopasowania są dodawane do zmiennej
  • Jeśli nie zostaną znalezione żadne dopasowania, zmienna $response zostanie ustawiona na „brak sugestii”