1 2 3 4 5 | <script> document.getElementById('tekstveld').innerHTML = "Hoi!"; </script> |
PHP-gegenereerd AJAX met SQL backend natuurlijkquote:Op zaterdag 24 maart 2007 23:00 schreef CraZaay het volgende:
Want dan denk je een betere user experience te bieden door de pagina steeds te herladen?
Nee, dan denk ik in een kortere tijd een beter werkende pagina te maken. Javascript biedt zeker voordelen, maar het is (met mijn kennis) erg lastig als het snel af moet. Als ik tijd heb ga ik er wel eens naar kijken, voorlopig even niet. Jullie zien me nog terug hier!quote:Op zaterdag 24 maart 2007 23:00 schreef CraZaay het volgende:
Want dan denk je een betere user experience te bieden door de pagina steeds te herladen?
Ik gebruik nog zelden PHP, maar zit dat er voortaan native in ja?quote:Op zaterdag 24 maart 2007 23:01 schreef Litpho het volgende:
[..]
PHP-gegenereerd AJAX met SQL backend natuurlijk.
Geen idee. Ik gebruik absoluut géén PHP, maar je hebt uiteraard niet noodzakelijk een framework nodig om AJAX te implementeren, je loopt alleen zonder het risico dat het na verloop van tijd enigszins onoverzichtelijk wordt.quote:Op maandag 26 maart 2007 13:28 schreef CraZaay het volgende:
[..]
Ik gebruik nog zelden PHP, maar zit dat er voortaan native in ja?
Een copy/paste van mijn huidige situatie:quote:Op woensdag 28 maart 2007 09:41 schreef SuperRembo het volgende:
In Firefox heb je de naturalWidth en naturalHeight properties waarmee je de goede hoogte kan berekenen. In IE kan je even een nieuwe img maken en daar de width en height van opvragen om de echte afmetingen te achterhalen.
Zie de scaleImage functie van FOK:)
1 2 3 | image.src = null; image.src = "http://www.server.com/"+directory+"/"+imageurl+".jpg"; |
1 2 3 | thumb.width = thumb.width / (thumb.height/100);; thumb.height = 100; |
1 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | { if (str.length > 0) { var url="ajax/updatepulldownEenheid.php?sid=" + Math.random() + "&id=" + str xmlHttp=GetXmlHttpObject(pulldownEenheidChanged) xmlHttp.open("GET", url , true) xmlHttp.send(null) } else { } } function pulldownEenheidChanged() { if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete") { // document.getElementById("txtHint").innerHTML=xmlHttp.responseText; hulp = xmlHttp.responseText; hulp = hulp.substring(0,1); //alert(hulp); if (hulp == '#') { //alert(hulp); document.getElementById("eenheid").innerHTML = ' '; } else { document.getElementById("eenheid").innerHTML = xmlHttp.responseText; } } } |
1 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | // clear down the dropdown before adding new entries into it. selectfield.options.length = 1; j=0; for (var i=0; i < data.length; i++) { if (data[i] == 'RETURN') { return true; } selectfield.options[j] = new Option(data[i], data[i]); j++; } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | <textarea id="mytextarea11">my test 1 2 3 </textarea> <textarea id="mytextarea12">my test2 4 5 6</textarea> <br> <input type="button" name="button" value="Submit" onclick="javascript:get(this.parentNode,1);"> </form> <br><br> Server-Response:<br> <hr> <span name="myspan1" id="myspan1">hoi?</span> |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | function makePOSTRequest(url, parameters, nr) { http_request = false; if (window.XMLHttpRequest) { // Mozilla, Safari,... http_request = new XMLHttpRequest(); if (http_request.overrideMimeType) { // set type accordingly to anticipated content type //http_request.overrideMimeType('text/xml'); http_request.overrideMimeType('text/html'); } } else if (window.ActiveXObject) { // IE try { http_request = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { http_request = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) {} } } if (!http_request) { alert('Cannot create XMLHTTP instance'); return false; } http_request.onreadystatechange = alertContents; http_request.open('POST', url, true); http_request.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); http_request.setRequestHeader("Content-length", parameters.length); http_request.setRequestHeader("Connection", "close"); http_request.send(parameters); } function alertContents() { if (http_request.readyState == 4) { if (http_request.status == 200) { //alert(http_request.responseText); result = http_request.responseText; document.getElementById("myspan1").innerHTML = result + "<input type="button" name="close" value="sluiten" onClick="sluit(1)">"; // alert("myspan"+nr+""); } else { alert('There was a problem with the request.'); } } if (http_request.readyState == 1) { document.getElementById("myspan1").innerHTML = "<img src='img.gif'>" } if (http_request.readyState == 2) { document.getElementById("myspan1").innerHTML = "<img src='img.gif'>" } if (http_request.readyState == 3) { document.getElementById("myspan1").innerHTML = "<img src='img.gif'>" } } function get(obj, nr) { var poststr = "mytextarea"+nr+"1=" + encodeURI( document.getElementById("mytextarea"+nr+"1").value ) + "&mytextarea"+nr+"2=" + encodeURI( document.getElementById("mytextarea"+nr+"2").value ); makePOSTRequest('update2.php', poststr, nr); } function sluit(nr) { document.getElementById("myspan"+nr).innerHTML = ""; } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | function makePOSTRequest(url, parameters, nr) { http_request = false; if (window.XMLHttpRequest) { // Mozilla, Safari,... http_request = new XMLHttpRequest(); if (http_request.overrideMimeType) { // set type accordingly to anticipated content type //http_request.overrideMimeType('text/xml'); http_request.overrideMimeType('text/html'); } } else if (window.ActiveXObject) { // IE try { http_request = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { http_request = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) {} } } if (!http_request) { alert('Cannot create XMLHTTP instance'); return false; } http_request.onreadystatechange = alertContents(nr); http_request.open('POST', url, true); http_request.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); http_request.setRequestHeader("Content-length", parameters.length); http_request.setRequestHeader("Connection", "close"); http_request.send(parameters); } function alertContents(nr) { if (http_request.readyState == 4) { if (http_request.status == 200) { //alert(http_request.responseText); result = http_request.responseText; document.getElementById("myspan"+nr+"").innerHTML = result + "<input type="button" name="close" value="sluiten" onClick="sluit("+nr+")">"; // alert("myspan"+nr+""); } else { alert('There was a problem with the request.'); } } if (http_request.readyState == 1) { document.getElementById("myspan"+nr+"").innerHTML = "<img src='img.gif'>" } if (http_request.readyState == 2) { document.getElementById("myspan"+nr+"").innerHTML = "<img src='img.gif'>" } if (http_request.readyState == 3) { document.getElementById("myspan"+nr+"").innerHTML = "<img src='img.gif'>" } } function get(obj, nr) { var poststr = "mytextarea"+nr+"1=" + encodeURI( document.getElementById("mytextarea"+nr+"1").value ) + "&mytextarea"+nr+"2=" + encodeURI( document.getElementById("mytextarea"+nr+"2").value ); makePOSTRequest('update2.php', poststr, nr); } function sluit(nr) { document.getElementById("myspan"+nr).innerHTML = ""; } |
1 2 3 | alertContents(nr); } |
check! :)quote:Op zondag 1 april 2007 10:41 schreef SuperRembo het volgende:
onreadystatechange moet een functie zijn die uitgevoer kan worden als de readystate van de request veranderd. In de oude versie is het inderdaad een functie, in de nieuwe versie wordt de functie alertContents meteen uitgevoerd en het resultaat (null/undefinded) wordt aan onreadystatechange toegekend.
Extra parameters doorgeven kan met behulp van een closure:
[ code verwijderd ]
hoe bedoel je dat? Het is de bedoeling dat er meerdere 'forms' komen (zoals dit dus-->)quote:Als je toch alle gegevens via javascript wil ophalen en de form submit niet gebruikt, dan kan je beter de hele form tag weg laten.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | <input id="mytextarea11" value="my test"> <input id="mytextarea12" value="my test"> <input type="button" name="button" value="Submit" onclick="javascript:get(this.parentNode,1);"> </form> <div id="myspan1"></div> meteen wat tekst? <form action="javascript:get(document.getElementById('myform'),2);" name="myform2" id="myform2"> <input id="mytextarea21" value="my test"> <input id="mytextarea22" value="my test"> <input type="button" name="button" value="Submit" onclick="javascript:get(this.parentNode,2);"> </form> <div id="myspan2"></div> meteen wat tekst? |
je bedoelt dmv style="display:none"?quote:In een onclick attribuut hoort javascript te staan, dus "javascript:" is daar overbodig.
Ik zou de sluit-knop gewoon in je html zetten. Standaard is ie verborgen, alleen als je 'm nodig hebt maak je 'm zichtbaar. Dat werkt een stuk makkelijker dan in javascript een hele button in innerHTML zetten. Hetzelfde geldt voor het 'busy' plaatje.
De action van het form doet hetzelfde als de onclick van de submit button. Ik vraag me af of die action überhaupt uitgevoerd wordt.quote:Op zondag 1 april 2007 15:13 schreef qu63 het volgende:
hoe bedoel je dat? Het is de bedoeling dat er meerdere 'forms' komen (zoals dit dus-->)
HTML
Ja.quote:je bedoelt dmv style="display:none"?
wordt idd niet uitgevoerd..quote:Op zondag 1 april 2007 15:59 schreef SuperRembo het volgende:
[..]
De action van het form doet hetzelfde als de onclick van de submit button. Ik vraag me af of die action überhaupt uitgevoerd wordt.
Maar is wel nodig voor de validatie van je document. Als dat je uberhaupt iets uitmaakt.quote:
Jup.quote:Op dinsdag 10 april 2007 14:36 schreef Geqxon het volgende:
Op wat voor manier moet er ingelogd worden? Een username / password veld op een pagina oid?
1 |
1 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | // functie 1 function getpageBody(name) { http.open("GET", urlpageBody + escape(name), true); http.onreadystatechange = function() { if (http.readyState == 4) { results = http.responseText; if(results!=''){ document.getElementById('PageVersion').innerHTML=getVersions(name); // dit gaat dus blijkbaar fout }else{ document.getElementById('PageVersion').innerHTML=' '; } } } http.send(null); } //functie 2 function getVersions(page) { http.open("GET", urlgetVersions + escape(page), true); http.onreadystatechange = function() { if (http.readyState == 4) { results = http.responseText; if(results!=''){ return http.responseText; }else{ return('leeg'); } } } http.send(null); } ?> |
Volgens mij begrijp jij het concept van AJAX niet helemaal. De eerste A staat namelijk voor asynchronous. Dit houdt in dat je functie niet gaat zitten wachten op input van de webserver. De hele onreadystate functie wordt pas aangeroepen op het moment dat de webserver iets terugstuurt. Je functie retourneert dus inderdaad nooit iets.quote:Op vrijdag 20 april 2007 11:20 schreef George.W.Bush het volgende:
Ik heb een javascript functie welke een andere functie aanroept.
functie 2 haalt via AJAX een aantal waarden op en zou die moeten returnen naar functie 1.
functie 1 moet vervolgens die values in een innerHMTL zetten:
[ code verwijderd ]
Zodra ik deze functies aanroep/ activeer, geeft mijn element PageVersions 'undefined' te zien.
Als ik in functie 2 de return verander in een document.write laat deze wel degelijk de te verwachten output zien. Maar deze output komt op de een of andere manier niet correct in functie 1 terecht.
Wat doe ik fout?
eh nee, die functie retourneert wel degelijk wat. De volgende regel:quote:Op vrijdag 20 april 2007 11:27 schreef cyberstalker het volgende:
[..]
Volgens mij begrijp jij het concept van AJAX niet helemaal. De eerste A staat namelijk voor asynchronous. Dit houdt in dat je functie niet gaat zitten wachten op input van de webserver. De hele onreadystate functie wordt pas aangeroepen op het moment dat de webserver iets terugstuurt. Je functie retourneert dus inderdaad nooit iets.
Je zult dus vanuit die functie zelf wat dingen moeten veranderen.
1 |
1 |
1 2 3 4 5 6 7 | <select onChange="getpageVersion(this.options[this.selectedIndex].value)"> <option selected="selected">Huidige versie</option> <option value="6">-1</option> <option value="2">-2</option> <option value="1">-3</option> </select> |
Je snapt het nog steeds niet. Het stuk vanaf de http.onreadystatechange = function() { tot en met de bijbehorende } wordt niet uitgevoerd totdat er een resultaat is. Dit is dus wat er direct wordt uitgevoerd:quote:Op vrijdag 20 april 2007 11:36 schreef George.W.Bush het volgende:
[..]
eh nee, die functie retourneert wel degelijk wat. De volgende regel:
[ code verwijderd ]
is wat helderder als je deze erbij hebt
[ code verwijderd ]
Nogmaals, als ik in functie 2 document.write('http.responseText'); schrijf ipv return http.responseText; krijg ik gewoon keurig datgene van de webserver te zien wat ik nodig heb.
1 2 3 4 5 | { http.open("GET", urlgetVersions + escape(page), true); http.send(null); } |
quote:Op vrijdag 20 april 2007 11:44 schreef cyberstalker het volgende:
[..]
Je snapt het nog steeds niet. Het stuk vanaf de http.onreadystatechange = function() { tot en met de bijbehorende } wordt niet uitgevoerd totdat er een resultaat is. Dit is dus wat er direct wordt uitgevoerd:
[ code verwijderd ]
En natuurlijk werkt een document.write daar. Die wordt dan uitgevoerd op het moment dat er een resultaat is. Op dat moment is jouw functie getVersions al gestopt zonder een returnvalue.
Klopt inderdaad. Verschil is alleen dat op het moment van die onreadystatechange de functie getVersions allang gestopt is. Die gaat daar niet op zitten wachten. Dat is het hele idee van dat asynchronous. Jij denkt in lineaire code en daar ga je de mist in.quote:Op vrijdag 20 april 2007 11:48 schreef George.W.Bush het volgende:
[..]
Die document.write wordt toch op hetzelfde moment uitgevoerd als die return. Die return vind pas plaats bij de onreadstate
Je bedoelt dat functie een al gestopt is?quote:Op vrijdag 20 april 2007 11:51 schreef cyberstalker het volgende:
[..]
Klopt inderdaad. Verschil is alleen dat op het moment van die onreadystatechange de functie getVersions allang gestopt is. Die gaat daar niet op zitten wachten. Dat is het hele idee van dat asynchronous. Jij denkt in lineaire code en daar ga je de mist in.
1 |
1 2 | setTimeout("document.getElementById('PageVersion').innerHTML="+version+"",1000); |
Je begrijpt het zo te zien nog steeds niet. Omdat ik niet het idee heb dat ik het je zo uit kan leggen dat je het zelf begrijpt heb ik hier een voorbeeldje dat zou moeten werken (niet getest):quote:Op vrijdag 20 april 2007 12:44 schreef George.W.Bush het volgende:
fuck, ook met een timertje ingebouwd werkt het niet.
[ code verwijderd ]
iemand nog een idee hoe ik functie 1 kan laten wachten op de results van functie 2?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | { http.open("GET", urlpageBody + escape(name), true); http.onreadystatechange = function() { if (http.readyState == 4) { results = http.responseText; if(results!='') { document.getElementById('PageVersion').innerHTML=results; } else { document.getElementById('PageVersion').innerHTML=' '; } } } http.send(null); } |
Zie de post boven je, ik heb iets soortgelijks gedaan. Ik begreep je wel, maar wist even niet hoe het op te lossen. Door inderdaad beide functie's in 1 functie te integreren is het probleem opgelost.quote:Op vrijdag 20 april 2007 13:29 schreef cyberstalker het volgende:
[..]
Je begrijpt het zo te zien nog steeds niet. Omdat ik niet het idee heb dat ik het je zo uit kan leggen dat je het zelf begrijpt heb ik hier een voorbeeldje dat zou moeten werken (niet getest):
[ code verwijderd ]
Dat valt wel mee volgens mij. http request 1 trekt de inhoud van een gekozen pagina uit de pagina tabel en plaatst die in mijn fckeditor (getPageBody). In deze funtie heb ik nu getVersions geintegreerd die via een xmlhttprequest een andere query uitvoert die uit de versie tabel het aantal versies van de gekozen pagina haalt en deze toont.quote:Sowieso is het vreemd dat je in zowel functie 1 als functie 2 een http request doet.
Maar waarom haal je niet in 1 request de pagina EN de bijbehorende versieinformatie tegelijk op?quote:Op vrijdag 20 april 2007 14:07 schreef George.W.Bush het volgende:
Dat valt wel mee volgens mij. http request 1 trekt de inhoud van een gekozen pagina uit de pagina tabel en plaatst die in mijn fckeditor (getPageBody). In deze funtie heb ik nu getVersions geintegreerd die via een xmlhttprequest een andere query uitvoert die uit de versie tabel het aantal versies van de gekozen pagina haalt en deze toont.
Ik bedacht me later dat dat zou kunnen, maar ik zie niet zo zeer de toegevoegde waarde van een join in mijn query tov 2 xmlhttprequest om de code aan te passen, of zie ik wat over het hoofd?quote:Op vrijdag 20 april 2007 17:12 schreef SuperRembo het volgende:
[..]
Maar waarom haal je niet in 1 request de pagina EN de bijbehorende versieinformatie tegelijk op?
Dat bedoelde ik dus. Is 1 'moeilijkere' query sneller dan twee html requests met 2 maal een simpele select?quote:Op vrijdag 20 april 2007 19:26 schreef SuperRembo het volgende:
Ik zeg niet dat je een join in je query moet stoppen, ik zeg alleen dat je waarschijnlijk beter die resultaten in 1 httprequest kunt versturen. Dat is sneller, belast de server minder en is makkelijker in javascript.
Het is natuurlijk niet zo dat er een 1-op-1 relatie is in het aantal requests en het aantal queries: je kunt met 1 httprequest prima zorgen dat je server side 2 queries uitvoert.quote:Op zondag 22 april 2007 20:17 schreef George.W.Bush het volgende:
[..]
Dat bedoelde ik dus. Is 1 'moeilijkere' query sneller dan twee html requests met 2 maal een simpele select?
Die javascript heb ik nu al, hoewel dit voor toekomstige aanpassingen inderdaad vragen om problemen is
Uiteraard de serverside kant kan natuurlijk van alles uitvoeren, het ging me nu om deze specifieke situatie.quote:Op zondag 22 april 2007 20:24 schreef CraZaay het volgende:
[..]
Het is natuurlijk niet zo dat er een 1-op-1 relatie is in het aantal requests en het aantal queries: je kunt met 1 httprequest prima zorgen dat je server side 2 queries uitvoert.
Waarom kun je in deze specifieke situatie dan niet met 1 httprequest zowel de inhoud van de pagina als de beschikbare versies ophalen? Of zie ik iets over het hoofd?quote:Op zondag 22 april 2007 20:46 schreef George.W.Bush het volgende:
[..]
Uiteraard de serverside kant kan natuurlijk van alles uitvoeren, het ging me nu om deze specifieke situatie.
Dat kan ookquote:Op zondag 22 april 2007 23:31 schreef CraZaay het volgende:
[..]
Waarom kun je in deze specifieke situatie dan niet met 1 httprequest zowel de inhoud van de pagina als de beschikbare versies ophalen? Of zie ik iets over het hoofd?
1 |
1 2 3 4 5 | var reponseData = eval(request.responseText); document.getElementById('PageBody').innerHTML = reponseData.body; document.getElementById('PageVersion').innerHTML = reponseData.version; } |
Hee, interessant! Ik ga dat JSon verder door lezen, ik neem aan dat ik er wat scripts voor op de server moet zetten?quote:Op maandag 23 april 2007 00:25 schreef SuperRembo het volgende:
Nogmaals, je hoeft geen join in je query te stoppen. Je kunt nog steeds die 2 simpele query's uitvoeren. De meeste snelheidswinst haal je doordat je browser niet 2x verbinding met de server hoeft te maken. (En als het een beveiligde pagina is waarvoor je ingelogd moet zijn hoef je maar 1x de sessie te controleren.)
Het is so wie so handig om te weten hoe je meerdere gegevens tegelijk te sturen. De X van ajax staat voor XML; je zou dus XML kunnen gebruiken, maar het werken met XML in javascript (en in PHP) is omslachtig. JSON (zie http://json.org) werkt veel makkelijker. Je stuurt met php bijvoorbeeld
[ code verwijderd ]
In javascript doe je weer een eval() van die tekst:
[ code verwijderd ]
Makkelijk uit te breiden, duidelijk leesbaar en snel![]()
Dus geen 'extra' scripts en dergelijke nodig, Out of the box?quote:JSON is a subset of the object literal notation of JavaScript. Since JSON is a subset of JavaScript, it can be used in the language with no muss or fuss.
PHP heeft vanaf versie 5.2 json_encode() en json_decode(). Om json in javascript te decoden kun je eval() gebruiken. De andere kant op gaat iets minder eenvoudig, maar daar zijn makkelijk scripts voor te vinden (bijv. op json.org). Json encoden in javascript heb je eigenlijk niet zo vaak nodig, alleen als je vanuit js (veel) gegevens terug wil posten naar de server.quote:Op maandag 23 april 2007 08:28 schreef George.W.Bush het volgende:
Dus geen 'extra' scripts en dergelijke nodig, Out of the box?
Maar als ik zoals jij hierboven op die manier echo'ed dan kan ik het ook dmv van var reponseData = eval(request.responseText); 'opdelen'? Daarvoor hoef ik geen extra scripts te installeren?quote:Op maandag 23 april 2007 08:40 schreef SuperRembo het volgende:
[..]
PHP heeft vanaf versie 5.2 json_encode() en json_decode(). Om json in javascript te decoden kun je eval() gebruiken.
Dat is inderdaad voor mij op dit moment niet van toepassing. Ik stuur een GET request naar de serverquote:De andere kant op gaat iets minder eenvoudig, maar daar zijn makkelijk scripts voor te vinden (bijv. op json.org). Json encoden in javascript heb je eigenlijk niet zo vaak nodig, alleen als je vanuit js (veel) gegevens terug wil posten naar de server.
Gegeven het feit dat Java niets te maken heeft met Javascript, zou deze opmerking niet meer waarheid kunnen bevatten als je je best zou doenquote:Op maandag 23 april 2007 09:17 schreef geertp het volgende:
Bij de beveiligingsinstellingen staat alles wat met Java te maken heeft ingeschakeld, dus daar zou het hem niet in moeten zitten.
Ik denk dat hij ook even goed moet kijken naar wat hij precies wel en niet aangevinkt heeftquote:Op maandag 23 april 2007 10:23 schreef Litpho het volgende:
[..]
Gegeven het feit dat Java niets te maken heeft met Javascript, zou deze opmerking niet meer waarheid kunnen bevatten als je je best zou doen.
Wat SuperRembo hierboven al zegt: wat let je om twee simpele queries uit te voeren als reactie op 1 request?quote:Op zondag 22 april 2007 23:55 schreef George.W.Bush het volgende:
[..]
Dat kan ookIk stel alleen een tegenvraag... maak het zoveel uit of ik 2 httprequest uitvoer ipv een moeilijke(re) query?
Daarnaast kun je het (bijvoorbeeld voor oudere PHP-versies) ook gewoon als string doen zoals in SuperRembo's voorbeeld.quote:Op maandag 23 april 2007 08:40 schreef SuperRembo het volgende:
[..]
PHP heeft vanaf versie 5.2 json_encode() en json_decode().
1 |
Nee. Die zorgen ervoor dat het een object is. Een object met waardes die je op naam kunt uitlezen.quote:Op maandag 23 april 2007 21:48 schreef SuperRembo het volgende:
Goeie vraag! Alleen weet ik niet of ik zelf wel helemaal begrijp.
De haakjes (de group operator) zorgen er in ieder geval voor dat wat er tussen staat als 1 statement wordt geëvalueerd (zoadat {..} een object wordt) en niet als serie statements (zodat {...} net als een functie-body uitgevoerd wordt).
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | var foo = {name: 'Bar', value: 'baz'}; // 1.b var foo; eval("foo = {name: 'Bar', value: 'baz'}"); // 1.c var foo = eval("({name: 'Bar', value: 'baz'})"); // 2.a var foo = ['Bar', 'baz']; // 2.b var foo; eval("foo = ['Bar', 'baz']"); // 2.c var foo = eval("['Bar', 'baz']"); |
Dat is omdat de [ ] voor een array staat en { } voor een object. Een gewone array kun je niet als associatieve array gebruiken, een object wel.quote:Op maandag 23 april 2007 22:31 schreef SuperRembo het volgende:
Nee. Het object is dat stuk tussen van { tot }.
[ code verwijderd ]
De vraag is waarom je bij 1.c wel een setje () nodig hebt, en bij het analoge geval 2.c bij een array niet.
Ja duh! [] staat voor array en {} voor object.quote:Op maandag 23 april 2007 22:58 schreef cyberstalker het volgende:
[..]
Dat is omdat de [ ] voor een array staat en { } voor een object. Een gewone array kun je niet als associatieve array gebruiken, een object wel.
Escapen?quote:Op maandag 23 april 2007 16:28 schreef George.W.Bush het volgende:
Hij gaat alleen over z'n nek van een enkele quote in mijn body tekst.
Ja ik trek de data serverside door htmlentities en rawurlencode, anders gaat het clientside script over z'n nek. En vervolgens decode ik clientside met unescape(responseData.body);quote:
Ik heb het met 'addslashes' geprobeerd, maar dan kreeg ik ook een foutmelding.quote:Op dinsdag 24 april 2007 12:37 schreef SuperRembo het volgende:
Belangrijke regel bij escapen/encoden: alleen doen als het nodig is, en gebruik het juiste type!
Dus als je (in php) een tekst in een js-string wil zetten, dan moet je de qoutes escapen met een backslash. Html-encoden is nergens voor nodig (het gaat namelijk niet om html).
Maar het gaat erom dat het in php encode wordt en dat ik het in javascipt moet decoden.quote:Escape() en unescape() in javascript kan je beter niet gebruiken. Wat escape() doet lijkt op urlencode() in php, maar het is net even anders. Je kunt beter encodeURIComponent() gebruiken om parameters voor een url te encoden. (encodeURIComponent bestaat alleen niet in IE5.0, maar da's toch een ouwe k***browser)
Addslashes zou voldoende moeten zijn. De rest (HTML-code) kan prima in een JS string afaik.quote:Op dinsdag 24 april 2007 15:34 schreef George.W.Bush het volgende:
Maar het gaat erom dat het in php encode wordt en dat ik het in javascipt moet decoden.
Dat was dus niet voldoende, gaf een foutmelding.quote:Op dinsdag 24 april 2007 23:48 schreef CraZaay het volgende:
[..]
Addslashes zou voldoende moeten zijn.
Onzin. Al eens van enters gehoord?quote:Op dinsdag 24 april 2007 23:48 schreef CraZaay het volgende:
[..]
Addslashes zou voldoende moeten zijn. De rest (HTML-code) kan prima in een JS string afaik.
Ik ga er vanuit dat zelfs iemand die minime JS kennis heeft dit weet. Dat heeft ook niets met de HTML entities te maken.quote:Op woensdag 25 april 2007 08:45 schreef cyberstalker het volgende:
[..]
Onzin. Al eens van enters gehoord?
En welke is dat dan precies?quote:Op woensdag 25 april 2007 08:18 schreef George.W.Bush het volgende:
[..]
Dat was dus niet voldoende, gaf een foutmelding.
quote:
1 2 3 4 5 | Bronbestand: http://intranet/includes/functions.js Regel: 11, Kolom: 7 Broncode: ({body:'<h2><font face=\"Verdana\">Welkom op Test\'s Intranet</font></h2> |
1 2 3 4 5 | http.open("GET", urlpageBody + escape(name), true); http.onreadystatechange = function() { if (http.readyState == 4) { var responseData = eval("("+http.responseText+")"); // hier dus |
Uiteraard zitten er linebreaks in die string, het is de body van een paginaquote:Op woensdag 25 april 2007 23:26 schreef CraZaay het volgende:
Er zitten geen line breaks in die string en hij wordt ook afgesloten met een enkele quote?
Die dubbele quotes hoef je trouwens niet te escapen.
Uiteraard?quote:Op donderdag 26 april 2007 11:28 schreef George.W.Bush het volgende:
[..]
Uiteraard zitten er linebreaks in die string, het is de body van een pagina.
Er valt weinig aan WYSIWYG editors als FCKeditor te doen die linebreaks uitspugen.quote:Op donderdag 26 april 2007 12:50 schreef CraZaay het volgende:
[..]
Uiteraard?
Linebreaks zijn geen onderdeel van de HTML ofzo. Dat jij ze er voor de leesbaarheid tussen zet is prima, maar JS gaat er wel van over z'n nek
quote:Op donderdag 26 april 2007 15:06 schreef Darkomen het volgende:
Doen dan! php? nl2br ;-)
Je wilt natuurlijk geen extra 's :-)
1 2 3 4 5 6 7 | // linebreaks weghalen $string = str_replace(array("\n","\r"),'',$string); // slashes escapen $string = str_replace("'","\'",$string); ?> |
Dit principe zeg maar:quote:Op vrijdag 27 april 2007 20:11 schreef SlimShady het volgende:
dat laatste moet lukken.
maar wat bedoel je met 'plaatje'? en de bedoeling?
1 |
Waar staat je site precies?quote:Op vrijdag 27 april 2007 20:30 schreef RayMania het volgende:
[..]
Dit principe zeg maar:
[ code verwijderd ]
Als je op het plaatje "/test.gif" klikt op de site, voegt het toe in aan favorieten bij IE. Bij andere browsers is er "Voeg toe aan favorieten!" te lezen. Ik wil in alle tijden een plaatje omdat dat mooier in de layout past.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>RayManiac</title> </head> <body> <script type="text/javascript"> /*********************************************** * Bookmark site script- © Dynamic Drive DHTML code library (www.dynamicdrive.com) * This notice MUST stay intact for legal use * Visit Dynamic Drive at http://www.dynamicdrive.com/ for full source code ***********************************************/ /* Modified to support Opera */ function bookmarksite(title,url){ if (window.sidebar) // firefox window.sidebar.addPanel(title, url, ""); else if(window.opera && window.print){ // opera var elem = document.createElement('a'); elem.setAttribute('href',url); elem.setAttribute('title',title); elem.setAttribute('rel','sidebar'); elem.click(); } else if(document.all)// ie window.external.AddFavorite(url, title); } </script> <img src="./test.gif" alt="Voeg toe aan favorieten!" onclick="bookmarksite(window.document.title,window.location.href)" /> </body> </html> |
Zet dan aub wel tekst in de html en laat dat weg en een plaatje zien dmv CSS. En geen pseudo-code maar in de onclick. Is het allemaal accessible en unobtrusivequote:Op vrijdag 27 april 2007 20:30 schreef RayMania het volgende:
[..]
Dit principe zeg maar:
[ code verwijderd ]
Als je op het plaatje "/test.gif" klikt op de site, voegt het toe in aan favorieten bij IE. Bij andere browsers is er "Voeg toe aan favorieten!" te lezen. Ik wil in alle tijden een plaatje omdat dat mooier in de layout past.
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |