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

Ajax – 2. lekceAjax – 2. lekce

 

Ajax – 2. lekce

Google       Google       24. 7. 2008       28 797×

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

Obrázek ke článku Nový IT hráč na českém trhu

Nový IT hráč na českém trhu

V roce 2015 otevřela v Praze na Pankráci v budově City Tower své kanceláře společnost EPAM Systems (NYSE:EPAM), jejíž centrála se nachází v USA. Společnost byla založená v roce 1993 a od té doby prošla velkým vývojem a stále roste.

Reklama
Reklama
Obrázek ke článku České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace (CRA) pořádají druhý ročník CRA IoT Hackathonů. Zájemci z řad vývojářů a fanoušků moderních technologií mohou změřit své síly a během jediného dne sestrojit co nejzajímavější funkční prototyp zařízení, které bude komunikovat prostřednictvím sítě LoRa. CRA IoT Hackathony se letos uskuteční ve dvou fázích, na jaře a na podzim, v různých městech České republiky. Jarní běh se odstartuje 31. března v Brně a 7. dubna v Praze.

Obrázek ke článku Cloud computing je využíván stále intenzivněji

Cloud computing je využíván stále intenzivněji

Využívání cloud computingu nabývá na intenzitě. Jen v letošním roce vzroste podle analytiků trh se službami veřejného cloudu o 18 %, přičemž o téměř 37 % vzrostou služby typu IaaS. Růst o více než pětinu pak čeká služby poskytování softwaru formou služby, tedy SaaS. Aktuálním trendům v oblasti využívání cloudu se bude věnovat konference Cloud computing v praxi, která se koná 23. března. 2017 v pražském Kongresovém centru Vavruška na Karlově náměstí 5.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý