DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   (X)HTML, JavaScript, DHTML, XML, CSS (http://www.devprotalk.com/forumdisplay.php?f=8)
-   -   AJAX pitanje (http://www.devprotalk.com/showthread.php?t=10438)

slavkan 15. 10. 2011. 01:40

AJAX pitanje
 
Pozdrav ekipi. Nesto se zezam sa JavaScript-om i javio mi se problem i javio mi se problem sa funkcijom "xmlhttp.open()". Da bi bilo jasnije ono sto meni treba moram malo da objasnim o cemu se radi. Hocu da ugradim filter da izlistavam neke proizvode na osnovu proizvodjaca, evo da bude jasnije postavicu kako izlistavam proizvodjace:
Kôd:

$query = 'SELECT * FROM proizvodjac';
$exec = mysql_query($query) or die (mysql_error());

echo'<form>
        <select name="users" onchange="showUser(this.value)">
        <option value="">Odaberi proizvodjaca:</option>';
       
        while ($row = mysql_fetch_assoc($exec))
        {
                echo'<option value="'.$row['idProizvodjac'].'">'.$row['naziv_proizvodjaca'].'</option>';}
                echo'</select>';
       
        echo'</form>
        <br />
        <div id="txtHint"><b>Proizvodi ce biti izlistani ovde.</b></div>';

E sad moja stranica gde mi se nalazi ova lista iznad ima sledeci link (konkretan primer za jednu od kategorija):
Kôd:

http://localhost/prodavnica/show-product.php?idKategorije=7
Sad ja moram da sa xmlhttp.open() metodom pozovem skript gde ce da se izvrsava ovaj upit koji ce da mi izlistava sve proizvode iz jedne kategorije po odabranom proizvodjacu. Toj skripti moram da prosledim ovaj naziv_proizvodjaca da bih mogao da kazem da mi da sve proizvode ciji je idKategorije = 7 a naziv proizvodjaca je onaj sto sam odabrao. Recimo da mi se taj skript gde ce ovaj upit izvrsavati zove filter.php. Znam da je neka osnovna definicija ove xmlhttp.open() funkcije nesto ovako:

Kôd:

xmlhttp.open("GET","filter.php?",true);
Sad ja na ovaj filter.php treba da nakalemim nekako naziv_proizvodjaca ali ne znam kako? Nadam se da ste me razumeli sta je problem, ne znam kako bih drugacije objasnio. Hvala

webarto 15. 10. 2011. 04:19

Garantovano ćemo da otvorimo link :)

Ne komplikuj sebi život... http://jquery.com/

PHP kôd:

$.ajax({
  
url'show-product.php?idKategorije=7',
  
success: function(data) {
    $(
'#form_div').html(data);
  }
}); 

Ne bi trebalo ovako da vraćaš gomilu HTML-a, trebao bi da vratiš JSON i onda da popuniš ovaj select... ako ništa barem samo select, nemaš potrebe čitavu formu...

Br@nkoR 15. 10. 2011. 11:40

Nešto kao:
Kôd:

'filter.php?naziv_proizvodjaca=' + encodeURIComponent(document.forms[0].users.options[document.forms[0].users.selectedIndex].text)

slavkan 21. 10. 2011. 03:22

Citat:

Originalno napisao webarto (Napišite 102156)
Garantovano ćemo da otvorimo link :)

Ne komplikuj sebi život... http://jquery.com/

PHP kôd:

$.ajax({
  
url'show-product.php?idKategorije=7',
  
success: function(data) {
    $(
'#form_div').html(data);
  }
}); 

Ne bi trebalo ovako da vraćaš gomilu HTML-a, trebao bi da vratiš JSON i onda da popuniš ovaj select... ako ništa barem samo select, nemaš potrebe čitavu formu...


E resio sam problem, hvala puno na sugestijama.

Imam sad jedan opasniji problem, verovatno ne opasan za one koji ovo dobro razumeju. Imam bazu kao neka prodavnica racunara i imam tabele sa kategorijama, proizvodima i proizvodjacima. Napravio sam jednu siromasnu f-ju koja mi na osnovu proizvoda pravi ponudu za sastavljanje konfiguracije racunara. Funkcija stampa kategorije i u select listu proizvode koji pripadaju toj kategoriji. Posto imam tabelu sa proizvodjacima zeleo bih da prvo pored svake kategorije odstampam listu sa proizvodjacima pa na osnovu odabranog proizvodjaca da mi se dinamicki stampaju proizvodi koji su vezani za taj proizvodjac. Napominjem da imam sve ove tabele kateogorija, proizvodjac, proizvod, kateogrija_proizvod,a nedoumica mi je jos da li bih morao da imam jos jednu tabelu kategorija_proizvodjac, mislim da da. Bio bih vam zahvalan kad bi malo pomogli da ovo izvedem. Evo te moje siromasne f-je:

Kôd:

function lista($naziv)
{
        $lista = "";
$upit = 'SELECT proizvod.idProizvod, proizvod.naziv_proizvoda, kategorija.naziv_kategorije
FROM proizvod
JOIN kategorija ON kategorija.idKategorija = (
SELECT kategorija.idKategorija
FROM kategorija
WHERE kategorija.naziv_kategorije =  "'.$naziv.'" )
JOIN kategorija_proizvod ON kategorija_proizvod.Kategorija_idKategorija = kategorija.idKategorija
AND kategorija_proizvod.Proizvod_idProizvod = proizvod.idProizvod
AND proizvod.stanje >0 ';
                                                                               
$s = mysql_query($upit) or die(mysql_error());
$br_redovaUbazi = mysql_affected_rows();

$i = 0;
$lista = '<div class="form_row"><label class="contact"><strong>'.$naziv.'<strong></label><select name="'.$naziv.'"><option value="-1">Odaberite</option>';
while ( $red = mysql_fetch_assoc($s) )
        {
                                                                       
$lista .= '<option value="'.$red['idProizvod'].'">'.$red['naziv_proizvoda'].'</option>';
$i++;
        }
                                                               
echo $lista .= '</select></div>';
}

echo lista("Procesor").' '.lista("Maticna ploca").' '.lista("Monitor").' '.lista("Hard disk").' '.lista("RAM").' '.lista("Graficka karta").' '.lista("Napajanje").' '.lista("Tastatura").' '.lista("Mis").' '.lista("Opticki uredjaj");
echo '</div><div class="form_row"><input type="submit" value="Naruci konfiguraciju! "></div></form>';


slavkan 21. 10. 2011. 17:21

Nasao sam i primer na netu kako bi moja lista trebala da se dinamicki kreira:

Kôd:

http://remysharp.com/wp-content/uploads/2007/01/select.html


Vreme je GMT +2. Trenutno vreme je 14:37.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.