DevProTalk

Forumi IT profesionalaca
web development, web design, e-business, SEO


Idite nazad   DevProTalk > Web development i web aplikacije > (X)HTML, JavaScript, DHTML, XML, CSS
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

(X)HTML, JavaScript, DHTML, XML, CSS Client scripting tehnologije, Dynamic HTML, Cascading Stylesheets, XML i standardi

Odgovori
 
Alati teme Način prikaza
Staro 15. 10. 2011.   #1
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default 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
slavkan je offline   Odgovorite uz citat
Staro 15. 10. 2011.   #2
webarto
expert
Grand Master
 
Avatar webarto
 
Datum učlanjenja: 11.04.2010
Poruke: 998
Hvala: 141
959 "Hvala" u 153 poruka
webarto is on a distinguished roadwebarto is on a distinguished roadwebarto is on a distinguished roadwebarto is on a distinguished roadwebarto is on a distinguished roadwebarto is on a distinguished roadwebarto is on a distinguished roadwebarto is on a distinguished road
Default

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...
__________________
Github // LinkedIn // PHP // ZCE // Stackoverflow PHP // Site5 Web Hosting
webarto je offline   Odgovorite uz citat
"Hvala" webarto za poruku:
Staro 15. 10. 2011.   #3
Br@nkoR
banned
Professional
 
Avatar Br@nkoR
 
Datum učlanjenja: 04.06.2005
Poruke: 371
Hvala: 0
738 "Hvala" u 83 poruka
Br@nkoR će postati "faca" uskoroBr@nkoR će postati "faca" uskoroBr@nkoR će postati "faca" uskoroBr@nkoR će postati "faca" uskoroBr@nkoR će postati "faca" uskoroBr@nkoR će postati "faca" uskoroBr@nkoR će postati "faca" uskoro
Default

Nešto kao:
Kôd:
'filter.php?naziv_proizvodjaca=' + encodeURIComponent(document.forms[0].users.options[document.forms[0].users.selectedIndex].text)
__________________
Don't look at me; I'm lost too.
“If you can't dazzle them with brilliance, baffle them with bul*s**t.”
Br@nkoR je offline   Odgovorite uz citat
Staro 21. 10. 2011.   #4
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default

Citat:
Originalno napisao webarto Pogledajte poruku
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 je offline   Odgovorite uz citat
Staro 21. 10. 2011.   #5
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default

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
slavkan je offline   Odgovorite uz citat
Odgovori


Alati teme
Način prikaza

Pravila pisanja
Možete ne započinjati nove teme
Možete ne slati odgovore
Možete ne slati priloge
Možete ne izmeniti svoje poruke
vB kôd je Uključen
Smajliji su Uključen
[IMG] kod je Uključen
HTML kôd je Isključen
Pogledajte forum


Vreme je GMT +2. Trenutno vreme je 01:02.


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.