Forum » Izdelava spletišč » jQuery, HTML in dodajanje oseb v div
jQuery, HTML in dodajanje oseb v div
marjan_h ::
Imam del HTML kode:
Del jQuery:
Kako bi v for zanki pravilno dodajal sporočila? HTML-ja NE smem spreminjati.
Jaz če bi tole delal, bi kar uporabil append za div levo. Pa dodajal tage.
Samo potem nima smisla imeti tiste span-e znotraj div-a levo.
Pri teh se uporablja atribut class, ker jih bo več.
Sporočilo je celo število 1,2,3... in se ne sme prikazati.
Ime se mora prikazati, ter tekst prav tako.
Recimo da beremo z tekstovne datoteke, katera je vsebina takšna:
Zanima me samo tisti del jQuery kode, ki pravilno doda sporočilo in ga prikaže.
Hvala za pomoč.
<div id="levo"> <div class="sporocilo"><span class="ime"></span><span class="tekst">Sporocila</span></div><hr/> </div>
Del jQuery:
$("#levo").empty();
Kako bi v for zanki pravilno dodajal sporočila? HTML-ja NE smem spreminjati.
Jaz če bi tole delal, bi kar uporabil append za div levo. Pa dodajal tage.
Samo potem nima smisla imeti tiste span-e znotraj div-a levo.
Pri teh se uporablja atribut class, ker jih bo več.
Sporočilo je celo število 1,2,3... in se ne sme prikazati.
Ime se mora prikazati, ter tekst prav tako.
Recimo da beremo z tekstovne datoteke, katera je vsebina takšna:
"1" "Andrej" "Danes me ne bo na kosilo" "2" "Marko" "Predstava je bila dobra" "3" "Anja" "Vsi ste vabljeni na piknik v soboto" ...
Zanima me samo tisti del jQuery kode, ki pravilno doda sporočilo in ga prikaže.
Hvala za pomoč.
marjan_h ::
aha potem dodam takole:
Si tako mislil?
In to izvedem v for zanki, toliko da prebere vse.
Se potem to generira v .html datoteki, ali je to samo trenutno?
$("#levo").html("<div class="sporocilo"><span class="ime">Andrej</span></div><hr/>");
Si tako mislil?
In to izvedem v for zanki, toliko da prebere vse.
Se potem to generira v .html datoteki, ali je to samo trenutno?
urosz ::
narekovaje bo treba popravit
kako pa misliš ti to brat z datoteke z javascript? ker to se namreč izvaja na klientovem računalniku, ki nima te datoteke lokalno ;)
kako to misliš, če se "generira v .html datoteki"? zdaj če boš šel gledat izvorno kodo, tega ne boš videl, ker tega ni bilo v fajlu, ki ti ga je posredoval strežnik. bo pa vidno na spletni strani, ker je brskalnik naknadno dodal to.
$("#levo").html('<div class="sporocilo"><span class="ime">Andrej</span></div><hr/>');
kako pa misliš ti to brat z datoteke z javascript? ker to se namreč izvaja na klientovem računalniku, ki nima te datoteke lokalno ;)
kako to misliš, če se "generira v .html datoteki"? zdaj če boš šel gledat izvorno kodo, tega ne boš videl, ker tega ni bilo v fajlu, ki ti ga je posredoval strežnik. bo pa vidno na spletni strani, ker je brskalnik naknadno dodal to.
radiokills ::
Jaz bi se na tvojem mestu (in na mestu vseh ostalih) izogibal takemu lepljenju stringov. Saj v konkretni situaciji še nekako gre, če boš pa dobil malo kompleksnejšo strukturo pa bo stvar postala nepregledna in zoprna za vzdrževanje. Jaz bi se tega lotil takole:
Funkcijo potem enostavno klices:
Sicer se tale koda izvaja nekoliko počasneje, kot če bi injectal direktno stringe, a v zameno dobiš veliko bolj pregledno pregledno kodo, ki jo je lažje vzdrževat.
function addMessage(personName, message, target){ //ustvari nove elemente var newdiv = $("<div>"); var nameSpan = $("<span>"); var messageSpan = $("<span>"); //zapisi ime v span nameSpan.html(personName); //zapisi sporocilo v span messageSpan.html(message); //poskrbi za css classe newdiv.addClass("sporocilo"); nameSpan.addClass("ime"); messageSpan.addClass("tekst"); //dodaj sporocilo in ime v div newdiv.html(nameSpan); newdiv.append(messageSpan); //dodaj crto newdiv.append("<hr />"); //Tako, sedaj imas vse sestavljeno, preostane nam le se, da dodamo novonarejeni element elementu na strani $(target).prepend(newdiv); }
Funkcijo potem enostavno klices:
addMessage("Janez Novak", "Janezovo sporocilo", "#levo");
Sicer se tale koda izvaja nekoliko počasneje, kot če bi injectal direktno stringe, a v zameno dobiš veliko bolj pregledno pregledno kodo, ki jo je lažje vzdrževat.
marjan_h ::
Hvala.
Zraven imam še obrazec, in ko klikneš na ime bi se moralo ime na katerega klikneš prenesti v vnosno polje.
Zelo preprosto, vendar ne dela.
Ali to zato ker se tisto generira na spletno stran naknadno in dejansko ni zapisano v html-ju?
Zraven imam še obrazec, in ko klikneš na ime bi se moralo ime na katerega klikneš prenesti v vnosno polje.
$(".ime").click(function(){ $("#vnos").val(this); });
Zelo preprosto, vendar ne dela.
Ali to zato ker se tisto generira na spletno stran naknadno in dejansko ni zapisano v html-ju?
illion ::
ja, ti bindaš click event še preden obstajajo vnosi, zato se nima kam bindat.
uporabi to:
http://api.jquery.com/on/
uporabi to:
http://api.jquery.com/on/
$('#levo').on('click', '.ime', function () { $("#vnos").val($this).html()); });
Vredno ogleda ...
Tema | Ogledi | Zadnje sporočilo | |
---|---|---|---|
Tema | Ogledi | Zadnje sporočilo | |
! | Vse, kar ste si želeli vprašati o CSS, pa si niste upali. (strani: 1 2 3 4 … 23 24 25 26 )Oddelek: Izdelava spletišč | 349819 (8956) | sunniegoldie |
» | javascript - gnezdenje - konkretno na mojem primeruOddelek: Programiranje | 2658 (2106) | geca |
» | JAVA skripta za Prestashop modulOddelek: Programiranje | 1342 (1280) | steev |
» | Kontakt obrazecOddelek: Izdelava spletišč | 2082 (1927) | betmen |
» | jquery in div-i (strani: 1 2 )Oddelek: Izdelava spletišč | 11437 (10175) | lisjak |