Ajax – 2. lekce
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Ajax – 2. lekceAjax – 2. lekce

 
Hledat
Moderní platforma pro vytvoření vašeho nového webu – Wix.com.
Nyní už můžete mít web zdarma.
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno

Ajax – 2. lekce

Google       Google       24. 7. 2008       30 081×

V dnešním článku se podíváme na metody a atributy XHR.

Reklama
Reklama

Metody a atributy XHR

Máme-li vytvořený XHR, nic nám nebrání k vytváření požadavků HTTP z JavaScriptu.

Metoda/vlastnost Popis
abort() Ukončí aktuální požadavek
getAllResponseHeaders() Vrátí hlavičky odpovědi jako řetězec
getAllResponseHeader("headerLabel") Vrátí jednu hlavičku odpovědi jako řetězec
open() Inicializuje parametry požadavku
send() Provede požadavek HTTP
setRequestHeader() Nastaví dvojici label/value hlavičky požadavku
onreadystatechange Používá se pro funkci zpětného volání, která ovládá změny stavu požadavku
readyState Vrátí stav požadavku: 0 = neinicializovaný 1 = načítání 2 = načten 3 = interaktivní 4 = dokončeno
responseText Vrátí odpověď serveru jako řetězec
responseXML Vrátí odpověď serveru jako dokument XML
Status Vrátí stavový požadavek
statusText Vrátí zprávu o stavu požadavku

Inicializace požadavku na server

Jako první budeme volat metodu open();.

void open(string metoda, string url,bolean asynch, string uzivatel, string heslo)

Metoda open je jako jediná pro inicializaci požadavku. Má dva povinné a tři nepovinné argumenty. První povinný argument je metoda, kterou volám (GET, POST, PUT), pak URL prostředku, který voláme. Jako volitelný parametr zadáváme, zda chceme volat asynchronní požadavek (hondota true – výchozí) nebo synchronní požadavek, hodnota false. Musím vás však upozornit, že použitím synchronního požadavku ztrácí smysl použití XHR. Poslední dva argumenty mluví za sebe.

Požadavek na server

Požadavek na server provedeme metodou send();.

void send(obsah);

Pokud posíláme požadavek jako asynchronní, vrací se řízení okamžitě, v opačném případě musíme čekat na odpověď serveru. Jako nepovinný argument můžeme použít instanci objektu DOM, vstupní tok nebo řetězec.

Atribut onreadyStateChange

Atribut onreadyStateChange použijeme pro zpětné volání a nastavíme ji pro ošetření požadavku. Tato metoda je volána několikrát, a to v případě, kdy se požadavek dostane do nového stavu.

Ukázka jednoduchého požadavku

Předpokladem pro vytvoření požadavku, je událost na straně klienta (onclick, onchange, onblur atd.), která zavolá funkci JavaScriptu (pojmenujme ji například vytvorPozadavek()). Funkce vytvorPozadavek() vytvoří instanci XHR voláním funkce vytvorXHR(), kterou jsme vytvořili v minulém díle. Dále pomocí metody open() nastaví parametry volání serveru. Požadavek odešleme metodou send().

 var xhr = vytvorXHR();
function vytvor pozadavek(){
   var url = "phpscript.php";
   
   xhr.open("POST",url);
   xhr.onreadystatechange = volanaFunkce; //dojde-li ke změně, volej funkci volanaFunkce
   xhr.send(null);
}

Jistě jste si všimli volání f-ce volanaFunkce při změně stavu požadavku. Tato funkce bude kontrolovat atribut readyState XHR a dále zjistí stavový kód přijatý od server (200 – pokud je vše OK; 404 – pokud prostředek nelze nalézt). Pokud bude kontrola úspěšná, provede akci, kterou ji určíme, jinak zobrazí hlášku o neúspěchu akce.

function volanaFunkce(){
   if(xhr.readyState == 4){ //funkci provedeme, pokud je požadavek ve stavu dokončeno
      if(xhr.status == 200){ //pokračuji, jen když je vše OK
         //akce, co má funkce provést
      }else{
         alert("Vámi definovaný prostředek nelze nalézt!");
      }
   }
}

Úkol

Vytvořte jednoduchý ajaxový script, který bude průběžně ověřovat data ve formuláři pro registraci do diskusního fóra. Nechávám vám volnou ruku s tím, že vyžaduji dodržení několika málo věcí. Formulář bude obsahovat uživatelské jméno, jméno, příjmení, e-mail a tlačítko odeslat, na které nebude možnost kliknout. Nick, jméno a příjmení budeme kontrolovat, zda byly údaje vyplněny a u e-mail bude provedena i kontrola, jestli je ve správném tvaru. Pokud uživatel něco špatně/nic nevyplní, vždy se zobrazí červená hláška pod daným polem. Jestliže vše bude vyplněno v pořádku, nastavíme tlačítko odeslat pro možnost kliknutí.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
Student ČVUT FJFI katedry softwarového inženýrství v ekonomii. Mezi jeho zájmy patří programování a sport. Autor má zkušenosti s PHP 5, MySQL, XHTML a CSS. Zajímá se o platformu .NET, jazyk C#, ASP.NET a WPF.
Web    

Nové články

Reklama
Reklama
Obrázek ke článku Pracujete u počítače ve stoje? Dbejte na správné držení těla

Pracujete u počítače ve stoje? Dbejte na správné držení těla

Práce ve stoje je jedna z variant, jak změnit polohu těla při dlouhodobé práci u počítače. Především je důležité nezapomínat na správné držení těla, abychom při práci nenamáhali naší krční páteř. Primářka MUDr. Michaela Tomanová představí hlavní bonusy a rizika práce u počítače ve stoje.

Obrázek ke článku Firmy musejí s nástupem Průmyslu 4.0 více dbát na kyberbezpečnost. V ohrožení je i jejich know-how.

Firmy musejí s nástupem Průmyslu 4.0 více dbát na kyberbezpečnost. V ohrožení je i jejich know-how.

Destabilizace firmy či ukradené know-how. To jsou možná hlavní budoucí rizika spojená s nedostatečnou kybernetickou bezpečností průmyslových firem, na která upozorňují experti. Vzhledem k postupující digitalizaci výrobních či technologických procesů a přechodu k takzvanému Průmyslu 4.0 může těchto hrozeb postupně přibývat. Varují před nimi i nejnovější průzkumy. 

Obrázek ke článku Nový CEBIT je připraven: Pochopit digitální dnešek a objevit digitální zítřek

Nový CEBIT je připraven: Pochopit digitální dnešek a objevit digitální zítřek

Nový veletrh  CEBIT je připraven. V polovině června začne v Hannoveru evropský festival obchodu s radikálně změněnou koncepcí věnovaný inovacím a digitalizaci.  CEBIT jedinečnou formou spojuje obchod v digitálním hospodářství 
s festivalovými prvky a posouvá do středu pozornosti téma digitální transformace hospodářství a společnosti.  

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032018 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý