DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   Sva početnička pitanja (http://www.devprotalk.com/forumdisplay.php?f=40)
-   -   Ajax, Jquery i PHP - Problem u IE (http://www.devprotalk.com/showthread.php?t=3816)

Croll 23. 10. 2007. 18:38

Ajax, Jquery i PHP - Problem u IE
 
Definitivno sam početnik u Ajax tehnologijama!

Rešio sam da iskoristim Ajax za pretraživanje. Pogledam kako to ljudi rade sa Jquery (dosta ga koristim pa je logično da i ovde radi), napravim i sve to radi kako sam zamislio u FF2 i Operi9.

Ne da mi đavo mira da proverim i u IE (kao što je i red) kad ono: !?"#@?^&%"!

Ogolim kod do običnog html-a, probam na još dve mašine...

Kada mi PHP ispisuje sadrža, ništa ne radi (u IE), dok kada učitavam običan txt fajl onda radi.

Inače, primeri koje sam gledao rade i u IE.

Sve je testirano na XAMP i on-line

Kod za učitavanje je sledeći:
Kôd:

$.post("ajaxsearch.php", {q: ""+inputString+""}, function(data){
        if(data.length >0) {
                $('#searchresults').show();
                $('#searchresults').html(data);
        }
});

i to funkcionise ok u FF i Operi.

Uostalom, na ovom linku imate primer - namerno sam ostavio da se vidi sadržaj foldera.

Kopija ajaxsearch.php u txt formatu da bi ga skinuli a izgleda ovako:
Kôd:

<?php

$Search = "<div class=\"sbihead2\">Pronadjeno: 4</div>\n<div class=\"sbicontent\">\n<ul class=\"sbilinks\">\n";

$Search .= "\t<li><a href=\"http://www.link.com\" title=\"Title linka\"><strong>Link</strong></a><br />Nam elit. Sed eros odio, accumsan et, vestibulum in, bibendum ullamcorper, nibh.</li>\n";
$Search .= "\t<li><a href=\"http://www.link.com\" title=\"Title linka\"><strong>Link</strong></a><br />Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Nulla venenatis, lectus id lacinia pretium, elit turpis dictum ante, eget venenatis turpis felis at leo.</li>\n";
$Search .= "\t<li><a href=\"http://www.link.com\" title=\"Title linka\"><strong>Link</strong></a><br />Praesent eu lectus vel leo placerat commodo. Aenean ullamcorper adipiscing erat. Nulla ut mauris sit amet velit pellentesque suscipit. Nunc ornare mattis ante. Ut pretium mi ac purus. In hac habitasse platea dictumst.</li>\n";
$Search .= "\t<li><a href=\"http://www.link.com\" title=\"Title linka\"><strong>Link</strong></a><br />Vestibulum pellentesque ligula sit amet pede. Proin quam. Fusce vitae augue. Vestibulum ac erat et nulla pharetra suscipit. Aliquam vitae ligula. Pellentesque vehicula mollis risus.</li>\n";

$Search .= "</ul>\n</div>\n</div>\n";
echo $Search;

?>

Znam da je problem glupav, u headeru ili sl. ali sam glupav da ga nadjem.

Unapred hvala

MrSteel 23. 10. 2007. 20:43

sta ti vraca alert(data) nakon izvrsenja
function(data) {
alert(data)
.
.
.
}

MorenoArdohain 23. 10. 2007. 20:47

Mislim da mu se u IE funkcija ne poziva na onkey. Treba istraziti zasto.

Misha 23. 10. 2007. 21:21

Zameni

$('#searchresults').html(data);

sa

$('#searchresults')[0].innerHTML = data;

Croll 24. 10. 2007. 06:07

Citat:

Originalno napisao MorenoArdohain (Napišite 45152)
Mislim da mu se u IE funkcija ne poziva na onkey. Treba istraziti zasto.

Poziva se funkcija, proverio. Ali isto ne radi link 'PHP Load' koji učitava iz PHP-a u DIV dok 'Text Load' radi što definitivno nema veze sa 'onkey'.

Citat:

Originalno napisao MrSteel (Napišite 45151)
sta ti vraca alert(data) nakon izvrsenja

Svugde vraća baš šta i treba, tačan 'echo' iz PHP-a ali ga Explorer ne smešta u DIV dok Opera i FF rade lepo.

Citat:

Originalno napisao Misha (Napišite 45153)
Zameni

$('#searchresults').html(data);

sa

$('#searchresults')[0].innerHTML = data;

Nažalost, neće ići, to bi trebalo da radi sam Jquery. U ovom obliku je neispravna Jquery sintaksa.

Da li kod vas radi u Exploreru? Probajte i linkove 'TXT Load' i 'PHP LOad' koji su realizovani preko Jquery funkcije:
Kôd:

$("a[@rel]").click(function() {$("#container").load(this.href, {thread_count: this.rel}); return false;});
Ista situacija, učitava HTML iz TXT fajla dok iz PHP-a Explorer neće da ga smesti gde treba.

conica 24. 10. 2007. 10:09

mozda je pucanj u prazno, ali pokusaj da referenciras umesto direktno na ID ovako:

Kôd:

$("div[@id='searchresults']").show();
$("div[@id='searchresults']").html(data);


Br@nkoR 24. 10. 2007. 11:09

Imaš grešku u sintaksi html kôda u php fajlu, postoji višak "</div>".


Nema veze sa problemom, ali nemoj na svaki keyup slati ajax zahtev, već postavim minimalan broj karaktera na koji šalješ, zatim sačekaj da korisnik napravi pauzu u kucanju pa tek onda šalji zahtev, odredi na koje karaktere je moguće slati zahtev, kada salješ zahtev sačekaj da se završi prethodni pa šalji novi. Postavi i neki indikator kada se šalje zahtev, kako bi korisnik znao.

MrSteel 24. 10. 2007. 12:03

nista, pucaj onda sa
document.getElementById("...").innerHTML
ako vec jQuery zeza, ja nisam doduse imao problema ali posalji njima primer mozda ce imati bolje objasnjenje

btw. explorer zna da odbije da prikaze sadrzaj kada je sintaksa neispravna

Croll 24. 10. 2007. 12:25

Citat:

Imaš grešku u sintaksi html kôda u php fajlu, postoji višak "</div>".
HVALA!!!

Pa da poludim od zamajavanja, totalno mi je promaklo. Izvinjavam se svima koji su odvojili vreme da pomognu, biću MNOGO pažljiviji ubuduće kod ovakvih običnih stvari. Fokusiraš se na nešto novo a ubije te običan copy-paste :1027:

Citat:

Nema veze sa problemom, ali nemoj na svaki keyup slati ajax zahtev, već postavim minimalan broj karaktera na koji šalješ, zatim sačekaj da korisnik napravi pauzu u kucanju pa tek onda šalji zahtev, odredi na koje karaktere je moguće slati zahtev, kada salješ zahtev sačekaj da se završi prethodni pa šalji novi. Postavi i neki indikator kada se šalje zahtev, kako bi korisnik znao.
Izuzetno korisni i dobrodošli saveti. Već sam primetio da prilikom kucanja imam višestruke pozive ali nisam hteo da obraćam pažnju na to dok ne rešim prvi problem.

U keyup funkciji je već predviđen minimum slova kada da pošalje zahtev ali sam ga skinuo radi testiranja.

Nije problem filtriranje karaktera, indikator, čekanje na prethodni load ali mislim da će mi biti problem čekanje na pauzu u kucanju.

Usvakom slučaju, još jednom najlepše hvala na pomoći i savetima, to je uvek dobrodošlo!

Br@nkoR 24. 10. 2007. 16:08

Citat:

Originalno napisao Croll (Napišite 45189)
ali mislim da će mi biti problem čekanje na pauzu u kucanju.

Npr.
Možeš odraditi tako što ćeš ajax zahtev slati sa malom pauzom, pomoću funkcije setTimeout.
Kôd:

var timeoutID = null;
function lookup(inputString) {
  if(inputString.length == 0) {
    $('#searchresults').hide();
  } else {
    clearTimeout(timeoutID);
    timeoutID = setTimeout(function () {
      $.post("ajaxsearch.php", {q: ""+inputString+""}, function(data){
        if(data.length >0) {
          $('#searchresults').show();
          $('#searchresults').html(data);
        }
      });
    }, 300);
  }
}

Dakle kada korisnik ukuca jedan karakter, id timeout-a biće zapisan u promenljivu timeoutID, ukoliko korisnik unese novi karakter pre isteka timeout-a, obrisaće se stari id, odnosno poništiće prethodni zahtev, pomoću clearTimeout i biće registrovan nov id, odnosno poslaće novi ajax zahtev, i tako sve dokle korisnik ne napravi pauzu u kucanju dužu od 300ms ili u zavisnosti vrednosti koju ti definišeš.


Vreme je GMT +2. Trenutno vreme je 13:39.

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.