DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   (X)HTML, JavaScript, DHTML, XML, CSS (http://www.devprotalk.com/forumdisplay.php?f=8)
-   -   jQuery .data ne pamti vrednost pri promeni konteksta (http://www.devprotalk.com/showthread.php?t=11273)

Nemanja Avramović 01. 11. 2012. 22:38

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?

Br@nkoR 01. 11. 2012. 23:35

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);

ivanhoe 01. 11. 2012. 23:51

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)

Nemanja Avramović 02. 11. 2012. 01:24

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.

webarto 02. 11. 2012. 02:02


:)

Br@nkoR 02. 11. 2012. 09:44

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();
}


ivanhoe 02. 11. 2012. 16:21

Citat:

Originalno napisao Nemanja Avramović (Napišite 109090)
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

Nemanja Avramović 02. 11. 2012. 16:29

^ 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 :)


Vreme je GMT +2. Trenutno vreme je 22:21.

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.