Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Problem mit XMLHTTP-Request aka AJAX

Empfohlene Antworten

Hallo Kollegen! :)

Ich habe hier ein Problem mit dem XMLHTTP-Request bzw. eher ein Problem

wie ich an das Problem rangehe.

Ich nutze hier einen (A)JAX-Request, der bisher syncron verlief.

Diesen wollte ich nun umgestalten, damit dieser asyncron verläuft.

Soweit kein Problem, der Request sieht vereinfacht so aus:


var xmlHttp;

function ajax_request_async(url, ziehlvoid, parameter) {

var xmlHttp = null;

try {

xmlHttp = new XMLHttpRequest();

} catch(e) {

try {

xmlHttp  = new ActiveXObject("Microsoft.XMLHTTP");

} catch(e) {

try {

xmlHttp  = new ActiveXObject("Msxml2.XMLHTTP");

} catch(e) {

xmlHttp  = null;

}

}

}

if(xmlHttp) {

xmlHttp.meinWert = parameter;

xmlHttp.open("GET", url+"&x="+new Date().getMilliseconds());

xmlHttp.send(null);

xmlHttp.onreadystatechange = ziehlvoid;

}

}

Das Funktioniert bisher, genauso wie der onreadystatechange-Eventhandler.

Das Problem beginnt mit dem Seitenaufruf, da dort mehrere asyncrone Requests gestartet werden. Logischerweise wird die globale Variable xmlHttp bei jedem neuen Request neu instanziert und überschrieben. Wenn nun die onreadystatechange-Funktion aufgerufen wird, dann wird das Ergebniss des Requests aus der aktuell verwiesenen xmlHttp-Objekt gelesen - dies ist aber der Knackpunkt, denn das Objekt ist dann nich zwangsläufig das Objekt, welches den Eventhandler aufgerufen hat. :(

Meine bisher einzige Idee wäre ein Array von xmlHttp-Objekten anzulegen und bei jedem Request ein neues xmlHttp-Objekt hinzuzufügen. Dann könnte ich alle xmlHttp-Objekte im Array durchlaufen und verarbeiten - nicht die optimale Lösung. :(

Die Anzahl der Requests ist (leider) dynamisch.

Wie könnte man das ganze Umgestalten?

Vermutlich ist mein Ansatz schon falsch - über Hilfe und Denkanstöße wäre ich dankbar! ;)

LG Lukas


function() {
var xmlHttp;
// ...
xmlHttp.onreadystatechange = function(/*params*/) { ziehlvoid(this /*=xmlHttp*/, /*params*/);}) ;

}
[/PHP]

Solange das Objekt nicht global ist, sollte es funktionieren (ungetestet).

Danke etreu!

An this hab ich gar nicht gedacht - vielen Dank! :D

Grüße, Lukas

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Konto

Navigation

Suchen

Suchen

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.