Ajax v praxi - upload souborů
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Ajax v praxi - upload souborůAjax v praxi - upload souborů

 
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 v praxi - upload souborů

Google       Google       15. 2. 2009       28 585×

Ajax přinesl do světa webdesignu mnoho nových možností. Jednou z nich je i uploadování souborů bez nutnosti obnovit stránku. Pojďme se na to podívat blíže.

Reklama
Reklama

Na úvod zmíním, na jakém principu bude skript fungovat. Klíčovou roli pro nás bude hrát skrytý iframe, v němž bude samotný proces probíhat. Postupovat budeme následujícím způsobem: nejdříve je potřeba vytvořit HTML formulář pro uploadování souborů a dále onen iframe. Vytvoříme funkci, která při zahájení nahrávání zobrazí animaci, a druhou funkci, která ji po dokončení nahrávání a následném zavolání move_uploaded_file() v PHP zase nechá zmizet. Začněme tedy s HTML formulářem. Bude nám stačit jeden input typu file a jeden submit button, důležitý pro nás však bude enctype parametr u tagu form.

Ovšem pouze toto nám k přípravě nestačí. Budeme potřebovat ještě jeden prvek, kde se nám zobrazí progress bar při nahrávání, a druhý prvek, kde uživatel zjistí, zda bylo nahrávání úspěšně dokončeno či nějakou chybou přerušeno. A konečně poslední část - skrytý iframe. A nesmíme zapomenout, že pracujeme - dá se říct - s JavaScriptem, tudíž je potřeba vložit do formuláře událost onSubmit.

Určitě jste si všimli, že se atributem target u formuláře dovoláváme iframu. Ve výchozím nastavení musíme skrýt blok s animací nahrávání, čili odstavec s identifikátorem progress_bar. Druhý odstavec je implicitně prázdný, nemusíme ho tedy nijak skrývat. Nyní je potřeba napsat jednoduchou JavaScriptovou funkci, která zobrazí progress bar, jakmile bude stisknuto tlačítko Nahrát. Není to nic složitého, zcela triviální funkce.

function zacitNahravani(){
  document.getElementById('progress_bar').style.visibility = 'visible';
  return true;
}

A nyní je samozřejmě potřeba ještě napsat funkci, která progress bar po ukončení nahrávání odstraní. Opět se bude jednat o pouhou změnu stylu, ovšem přibyde nám také parametr a další úkony. Pomocí parametru funkce zjistí, zda byl soubor úspěšně nahrán, či se někde vyskytla chyba, a dle toho přizpůsobí obsah odstavce s identifikátorem vysledek. Budeme tedy potřebovat jednoduchou konstrukci if..else a metodu innerHTML z objektu document. Celá funkce bude vystavěna následujícím způsobem:

function konecNahravani(stav){
  var result = '';
  if (stav == 1){
    document.getElementById('vysledek').innerHTML = 'Nahrávání proběhlo úspěšně!

'; } else { document.getElementById('vysledek').innerHTML = 'Při nahrávání došlo k chybě!

'; } document.getElementById('progress_bar').style.visibility = 'hidden'; return true; }

Možná si říkáte, že Ajax vůbec nepoužíváme. Ono je to docela pravda. Celé to je jen o JavaScriptu a PHP - odeslání formuláře proběhne v neviditelném iframu upload a stránka se nemusí znovu načítat. A tento průběh se Ajaxu velmi podobá. Ale zpět ke skriptům. HTML a JavaScript máme za sebou a zbývá nám pouze příprava CSS a PHP. Prvně připravím styl pro 2 prvky - je potřeba do základu skrýt progress bar a ještě si trochu pohrát se stylem formuláře.

p#progress_bar{
  z-index: 100;
  position: absolute;
  visibility: hidden;
  text-align: center;
  width: 400px;
  margin: 0px;
  padding: 0px;
  background-color: #fff;
  border: 1px solid #ccc;
}
 
form{
  text-align: center;
  width: 390px;
  margin: 0px;
  padding: 5px;
  background-color: #fff;
  border: 1px solid #ccc;
 
}

A dostáváme se k poslední části - k PHP skriptu. Místo, kam se budou soubory nahrávat, necháme jako pracovní adresář, dále zavedeme pomocnou proměnnou vysledek, kterou použijeme jako parametr pro funkci konecNahravani(). Tato proměnná dostane hodnotu 0 a v případě úspěšného nahrání souboru se přepíše na 1. Na konci skriptu je ještě použit příkaz sleep, to proto, aby se zobrazila animace i při velmi rychlém až okamžitém nahrání.

A na závěr poslední JavaScript, kde budeme volat funkci konecNahravani() s parametrem $vysledek z PHP skriptu.

A to je vše. V dalším pokračování se podíváme na RSS čtečku.

Zdroj: http://www.ajaxf1.com/

×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
(fotka) Tomáš BobekAutor je designérem stránek (2D grafika), ovládá jazyky HTML, CSS, PHP, JavaScript a zajímá se o programování v Javě.Krom programujte.com se podílí na projektech maths.cz (jako redaktor a grafik), ceskewebstudio.cz (jako designér) a webber.cz (jako JavaScript scriptař). Ostatní volný čas rád tráví s přáteli nebo sportuje (tenis, nohejbal, hokejbal, závodně fotbal).
Web     Twitter     Facebook    

Nové články

Obrázek ke článku Průmyslové firmy chtějí zkrátit proces přijímání lidí ze zemí mimo EU. Inspiraci vidí v Polsku.

Průmyslové firmy chtějí zkrátit proces přijímání lidí ze zemí mimo EU. Inspiraci vidí v Polsku.

Pokud chtějí průmyslové firmy v Česku obsadit volné místo uchazečem ze země mimo Evropskou unii, znamená to pro ně i půlroční čekání. Výrazně to přitom pociťuji i na vynaložených nákladech. Svaz průmyslu a dopravy chce proto zkrátit měsíční lhůtu vyvěšení volné pozice na Úřadu práce. Průmyslové firmy a personalisté by však volili komplexnější zjednodušení, o pracovní povolení by měli žádat přímo zaměstnavatelé. Jako vzor uvádějí dlouhodobě fungující systém v Polsku či Maďarsku.

Reklama
Reklama
Obrázek ke článku Pět mýtů spojených s tvorbou e-shopů

Pět mýtů spojených s tvorbou e-shopů

Chuť Čechů nakupovat online stále roste a internetovým obchodům se v Česku daří. I proto o vlastním e-shopu přemýšlí i podnikatelé, kteří si dosud vystačili s kamennou prodejnou nebo profilem na sociální síti či prodejním portálu. Kolem samotné tvorby webu však stále panuje řada mýtů, které mnohdy od založení e-shopu zbytečně odrazují

Obrázek ke článku Konference: Cloud computing rychle mění firemní IT

Konference: Cloud computing rychle mění firemní IT

Cloud computing se během několika posledních let stal samozřejmostí a jeho využití stále roste. Drtivá většina velkých firem již disponuje multicloudovou strategií, v průměru používají více než 3 cloudy současně a s dalšími experimentují. Co přesně cloud firmám přináší? Na jaké problémy lze při jeho využívání narazit? I na tato témata se zaměřuje konference Cloud computing v praxi, která se koná 21. 3. 2019 v pražském Kongresovém centru Vavruška na Karlově náměstí 5.

Obrázek ke článku Soutěž Startupper roku zná finalisty. Odborná porota bude nyní vybírat mezi 14 nejlepšími projekty

Soutěž Startupper roku zná finalisty. Odborná porota bude nyní vybírat mezi 14 nejlepšími projekty

Letos v České republice poprvé probíhá soutěž Startupper roku, kterou pořádá společnost Total v rámci celosvětového projektu „Startupper of the Year by Total“. Soutěž je určena všem českým podnikatelům a podnikatelkám mladším 35 let, kteří během uplynulých dvou let vytvořili projekt nebo start-up s dopadem na sociální sféru a komunitu. Projekt musí obsahovat praktický způsob řešení záležitostí v oblasti zdravotnictví, bezpečnosti, vzdělávání, přístupnosti a dalších oblastí, které ovlivňují místní komunity. 

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