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 01. 11. 2012.   #1
Nemanja Avramović
emperor Selassie
Grand Master
 
Avatar Nemanja Avramović
 
Datum učlanjenja: 20.10.2006
Lokacija: Mladenovac
Poruke: 754
Hvala: 361
576 "Hvala" u 88 poruka
Nemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoro
Pošaljite ICQ poruku za Nemanja Avramović Pošaljite poruku preko MSN za Nemanja Avramović Pošaljite poruku preko Yahoo za Nemanja Avramović
Default jQuery .data ne pamti vrednost pri promeni konteksta

Situacija je sledeća: Imam više slika na stranici, klikom na njih otvaram dijalog (klasičan lightbox/iframe) za upload nove slike. Kada se izabere slika vrši se klasičan upload i na toj stranici se ispisuje JS kod koji menja sliku na koju je kliknuto.

HTML:
HTML kôd:
<img src="default-thumb.jpg" data-big="default.jpg" />
<img src="default-thumb.jpg" data-big="default.jpg" />
<img src="default-thumb.jpg" data-big="default.jpg" />
<img src="default-thumb.jpg" data-big="default.jpg" />
JS:
PHP kôd:
//ovo ide u document.ready
$('img').click(function() {
//oznacim sliku (trebace mi kasnije)
$(this).addClass('replace-this-image');
//otvori lightbox
$.lightbox('replace.php');
}); 
replace.php (nakon sto sačuva uploadovani fajl)
PHP kôd:
$(document).ready(function () {

//cisto primer, PHP generiše ovaj JS objekat
var slikaObj = {uri'putanja/do/thumb-slike.jpg'big'putanja/do/slike.jpg'}; 

//dohvatam DOM slike
var slika = $('.replace-this-image'window.parent.document); //probao sam i sa window.parent.$('.replace-this-image'); i dobijam iste rezultate

//postavljam src, data('big') i uklanjam css klasu
$(slika).attr('src'slikaObj.uri);
$(
slika).data('big'slikaObj.big);
$(
slika).removeClass('replace-this-image');

//test
alert($(slika).data('big')); //dobijam putanja/do/slike.jpg, očekivano

window.parent.$.lightbox.close(); //zatvaram popup dialog
}); 
Kada se zatvori lightbox i opet pročitam data-big vrednost slike koja je promenjena(alert($(slika).data('big'));), dobijam prvobitnu vrednost (default.jpg) dok sve ostalo radi (src je promenjen). Kako da i nakon zatvaranja lightboxa data('big') ima vrednost koja je postavljena iz iframe-a?
__________________
Moj portfolio sajtić | wat?

Poslednja izmena od Nemanja Avramović : 01. 11. 2012. u 23:41.
Nemanja Avramović je offline   Odgovorite uz citat
Staro 02. 11. 2012.   #2
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

Umesto:
Kôd:
$(slika).data('big', slikaObj.big);
Stavi:
Kôd:
$(slika).attr('data-big', slikaObj.big);
ili
Kôd:
parent.$(slika).data('big', slikaObj.big);
http://api.jquery.com/data/
Citat:
The data- attributes are pulled in the first time the data property is accessed and then are no longer accessed or mutated (all data values are then stored internally in jQuery).
Dakle ti ga izmeniš/sačuvaš u jQuery u iframe-u koji posle uništavaš.

EDIT:
Možeš i ovo:
Citat:
//probao sam i sa window.parent.$('.replace-this-image'); i dobijam iste rezultate
Ali onda koristi
Kôd:
slika.data('big', slikaObj.big);
__________________
Don't look at me; I'm lost too.
“If you can't dazzle them with brilliance, baffle them with bul*s**t.”

Poslednja izmena od Br@nkoR : 02. 11. 2012. u 00:41.
Br@nkoR je offline   Odgovorite uz citat
"Hvala" Br@nkoR za poruku:
Staro 02. 11. 2012.   #3
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

glupa ideja, sta se desi ako umesto $(document).ready() stavis $(top.document).ready()?

btw, slika ti je vec jQuery objekat, ne moras svugde da pises $(slika)
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Staro 02. 11. 2012.   #4
Nemanja Avramović
emperor Selassie
Grand Master
 
Avatar Nemanja Avramović
 
Datum učlanjenja: 20.10.2006
Lokacija: Mladenovac
Poruke: 754
Hvala: 361
576 "Hvala" u 88 poruka
Nemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoro
Pošaljite ICQ poruku za Nemanja Avramović Pošaljite poruku preko MSN za Nemanja Avramović Pošaljite poruku preko Yahoo za Nemanja Avramović
Default

Hvala Branko, na kraju sam zaobišao postojeći jQuery objekat i radi ovako:
PHP kôd:
window.parent.$('img.replace-this-image').data('big'slikaObj.big); 
Ivane, hvala na sugestiji, promenio sam da koristim samo slika.func(...) mada mi je i dalje lepše sa $(slika).func(...)

Što se tiče $(top.document).ready() - nisam probao (i ne moram sad kad radi) ali mislim da ne bi radilo jer je top.document ready opaljen kad se prethodna strana (koja otvara lightbox) učitala, odnosno pre nego što se lightbox kreira uopšte, ako se ne varam.
__________________
Moj portfolio sajtić | wat?
Nemanja Avramović je offline   Odgovorite uz citat
Staro 02. 11. 2012.   #5
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


__________________
Github // LinkedIn // PHP // ZCE // Stackoverflow PHP // Site5 Web Hosting
webarto je offline   Odgovorite uz citat
4 članova zahvaljuje webarto za poruku:
Staro 02. 11. 2012.   #6
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

Možda da uradiš malo drugačije, da u replace.php po upload-u fajla odradiš:
Kôd:
parent.uploadFinishedCallback({uri: 'putanja/do/thumb-slike.jpg', big: 'putanja/do/slike.jpg'});
A da u glavnom/parent prozoru, imaš:
Kôd:
function uploadFinishedCallback(data) {
  $('.replace-this-image').attr('src', data.uri).data('big', data.big).removeClass('replace-this-image'); 
  $.lightbox.close();
}
__________________
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 02. 11. 2012.   #7
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

Citat:
Originalno napisao Nemanja Avramović Pogledajte poruku
mada mi je i dalje lepše sa $(slika).func(...)
zato ja jquery varijable nazivam sa $ na pocetku.. znaci $slika i odmah znas sta je
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Staro 02. 11. 2012.   #8
Nemanja Avramović
emperor Selassie
Grand Master
 
Avatar Nemanja Avramović
 
Datum učlanjenja: 20.10.2006
Lokacija: Mladenovac
Poruke: 754
Hvala: 361
576 "Hvala" u 88 poruka
Nemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoro
Pošaljite ICQ poruku za Nemanja Avramović Pošaljite poruku preko MSN za Nemanja Avramović Pošaljite poruku preko Yahoo za Nemanja Avramović
Default

^ pametno Mislim da u ovom ovde slučaju nije frka ni sa $(slika) pošto nemam na hiljade operacija koje treba izvršiti, već 4-5 linija koda. Ali svakako je dobra praksa ne koristiti uvek $(slika), pogotovo ako se radi sa nekim petljama
__________________
Moj portfolio sajtić | wat?
Nemanja Avramović je offline   Odgovorite uz citat
Odgovori



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:14.


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.