Home / LinuxUser / 2006 / 10 / Websites programmieren mit AJAX

Newsletter abonnieren

Lies uns auf...

Folge LinuxCommunity auf Twitter

Top-Beiträge

Mandriva gibt Distribution in die Hände der Community
(268 Punkte bei 24 Stimmen)
Neues vom Systemd
(179 Punkte bei 5 Stimmen)
Mandriva in Nöten
(161 Punkte bei 4 Stimmen)
Mageia 2 ist fertig
(161 Punkte bei 4 Stimmen)

Heftarchiv

LinuxUser Heftarchiv

EasyLinux Heftarchiv

Ubuntu User Heftarchiv

Ubuntu User Heftarchiv

Partner-Links:

Shopping
Topsuche
 
Yatego Deutschlands größte Shoppingmall. 10000 Shops,
3.5 Mio Artikel. Alle Bestseller, Servertechnik und Technik Themenwelten.

Notebooks und Netzwerkhardware bei Mercateo günstig kaufen.
Internet Telefonie mit VoIP Telefonen von Gigaset
Das B2B Portal www.Linx.de informiert über Produkte und Dienstleistungen.
Günstige Digitalkameras finden Sie im Preisvergleich.

Schneller, höher, weiter

Websites programmieren mit AJAX

Inkompatibilitäten

Soweit die Theorie. Doch wie so häufig bei der Entwicklung von Webanwendungen sieht die Praxis etwas anders aus. Jeder Browser kocht sein eigenes Süppchen, und so muss der AJAX-Programmierer, versuchen mit diesen Eigenheiten zurecht zu kommen.

Los geht es mit dem Internet-Explorer, dessen aktuelle Versionen das XML-Request-Objekt nicht implementieren – zumindest nicht so, dass der Aufruf von XMLHttpRequest() zum gewünschten Ergebnis führt. Bei Microsoft gilt es dafür ein entsprechendes ActiveX-Objekt zu erzeugen, das sich glücklicherweise sonst so verhält wie die hier beschriebenen Request-Objekte. Tatsächlich ist sogar noch eine weitere Variante nötig, denn verschiedene Versionen des Internet Explorer erfordern unterschiedliche Syntax.

Weitere Problemkinder sind der KDE-Konqueror und der Apple-Browser Safari, denen manche Javascript-Konstrukte zur Manipulation des DOM-Baumes Schwierigkeiten bereitet. So funktioniert bei ihnen nicht die beschriebene Vorgehensweise, über die Dokumentenfunktion getElementById() an das zu verändernde Element zu gelangen. Das hier vorgestellte AJAX-Beispiel finden Sie noch einmal vollständig und mit allen Browser-Workarounds online unter [3].

Die Funktion checkResult() des Listings demonstriert außerdem, wie man die Interaktion noch dynamischer gestalten kann. Wie bereits in der letzten Variante setzt es das Span-Element nur auf das Ergebnis, wenn die Anfrage abgeschlossen ist (Zustand 4). Bei allen anderen Zustandsänderungen, die ja schon beim Aufbau der Verbindung beginnen, ändert es den Text auf Lade.., sodass der Benutzer sofort ein Feedback darüber erhält, dass etwas passiert.

Hilfe im Netz

Wie man sieht, erfordern AJAX-Webanwendungen etwas mehr Programmieraufwand als konventionelle Webseiten. Das beginnt schon beim Design: Nicht jede Website ist auch dafür geeignet, "ajaxifiziert" zu werden. Gute Planung ist deshalb noch wichtiger als bei der klassischen Webentwicklung. Schließlich muss für jeden AJAX-Abschnitt in einer Seite ein entsprechendes Skript auf dem Server bereitstehen. Außerdem benötigt der Javascript-Code jeder AJAX-Anwendung genaue Kenntnis über den Aufbau der Seiten. Cascading Stylesheets (CSS) verhelfen hier zu besserer Struktur, vergrößern aber die Anzahl an Dateien noch einmal.

Hilfreich sind die zahlreichen Javascript- und AJAX-Bibliotheken im Internet. So kapselt etwa Sajax [4] AJAX-Anfragen und die Verarbeitung der Antworten, damit Sie sich nicht mehr um Browser-Inkompatibilitäten und Ähnliches kümmern müssen. Mehr Komfort bieten beispielsweise Rico [5] oder die Yahoo User Interface Library (YUI) [6], die beide über die AJAX-Kommunikation hinaus auch noch eine Menge Funktionen für den Aufbau dynamischer HTML-Oberflächen mitbringen.

Einem Freund empfehlen    Druckansicht Bookmark and Share
Kommentare

Hits
Wertung: 69 Punkte (1 Stimme)

Schlecht Gut

Infos zur Publikation

Infos zur Publikation

LinuxUser 06/2012

Aktuelle Ausgabe kaufen:

Heft bestellen Heft als PDF kaufen

LinuxUser erscheint monatlich und kostet in der Nomedia-Ausgabe EUR 5,50 und mit DVD EUR 8,50. Weitere Informationen zum Heft finden Sie auf der LinuxUser-Homepage.

Im LinuxUser-Probeabo erhalten Sie drei Ausgaben für 3 Euro. Das Jahresabo (ab EUR 56,10) können Sie im LNM-Shop bestellen.

Tipp der Woche

Adobe AIR
Adobe-AIR-Programme installieren und (manuell) starten
Tim Schürmann, 14.05.2012 13:09, 0 Kommentare

Es gibt sie noch: neue Anwendungen, die Adobes Integrated Runtime voraussetzen. Aktuellstes und vermutlich auch größtes Beispiel ist das Adventure Botanicula

Aktuelle Fragen

gibt es ein Kommandozeilen Tool, um ein X11-Fenster in ein Anderes einzubetten?
GoaSkin , 21.05.2012 16:44, 0 Antworten
Das XEmbed-Protokoll ist u.A. dazu gedacht, dass man eine X11-Anwendung in eine andere wie ein Wi...
Apache2, Options -Indexes geht nicht
no no, 12.05.2012 19:01, 8 Antworten
Habe in apache2.conf folgendes stehen: Options -Indexes ...
LInux auf Dell LS H500
Andreas Endresl, 09.05.2012 08:54, 2 Antworten
Habe einen alten Dell Latitude LS H500 nur mit ext. Floppy und CD es geht nur immer eines von den...
Datenwiederherstellung unter Ubuntu 12.04 mit "Simple Backup" nach Umzug von Linux Mint
Christian Lottmann, 07.05.2012 13:33, 0 Antworten
Vor dem Umzug auf Ubuntu 12.04 habe ich unter Linux MInt mit "Simple Backup" voll (15.4.2012) und...
DKMS für den propritären NVIDIA-Treiber
Commander Data, 26.04.2012 22:02, 2 Antworten
Hallo an die Gemeinde. Ich habe hier ein interessantes Stück openSuSE gefunden. http://forums.op...