Autor Thema: Dynamische Ajax-Navigation auf Xpage  (Gelesen 4032 mal)

Xpager

  • Gast
Dynamische Ajax-Navigation auf Xpage
« am: 23.08.10 - 12:40:28 »
Hallo,

ich möchte bei meiner Xpage eine Navigation einbauen, die es erlaubt, dass nur bestimmte Bereiche einer Website per Ajax aktualisiert werden.

Die Navigation besteht bei mir bisher aus Links, die dann einfach eine neue Seite öffnen. Dabei wird aber immer die ganze Seite neu geladen. Ich möchte, dass wenn man auf einen Navi-Link klickt, nur ein bestimmter Bereich - der Inhaltsbereich - aktualisiert wird.

Weiß jmd. wie man das hinkriegt? Bzw. wo es ein Tutorial dazu gibt?

Offline heini_schwammerl

  • Gold Platin u.s.w. member:)
  • *****
  • Beiträge: 697
  • Geschlecht: Männlich
Re: Dynamische Ajax-Navigation auf Xpage
« Antwort #1 am: 26.08.10 - 19:08:06 »
Ich bin leider aus der jQuery Fraktion aber dieser Link (auf Englisch) befasst sich mit der Problematik.
http://www.digitalsanctuary.com/tech-blog/general/why-i-like-jquery-over-dojo.html

Soviel ich weiss ist in den XPages so etwas schon berücksichtigt (Partial Refresh / Partial Update)
Zum Beispiel hier:
http://www-10.lotus.com/ldd/ddwiki.nsf/dx/XPages_Partial_Update.htm
http://www.youtube.com/watch?v=KQ8JFhi2p1M
http://dominoextnd.blogspot.com/2009/11/xpages-loading-images-and-masking.html

Allerdings wird hier oft nicht direkt das Laden von externen Dateien direkt gezeigt, der letzte Link sollte aber stark in Deine Richtung gehen.

Nachteile von Ajax Lösungen sind.
Die Url im Browser ändert sich beim Update nicht (es gibt allerdings Erweiterungen bzw. Hacks mit dem "#" Tag.
Wenn es sinnvoll ist Seiten zu "bookmarken" muss man die Bookmark Url in das Design (den Ajax Request) integrieren.
Einige Plug-Ins, zum Beispiel Flash Integration in Verbindung mit Lightbox Effekten zicken rum.
Mit einem Ajax Request wird trotzdem immer die ganze Seite geladen, dann gefiltert und der Inhalt in die vorhandene Seite eingefügt.
Ist die Verbindung des Benutzers langsam führt das daher nicht immer zu einer Beschleunigung.

In jQuery würde es so funktionieren.
Man erzeugt eine ganz normale Linkliste mit Links auf die komplett neue Seite und weist diesen Link zum Beispiel eine CSS Klasse zu.
jQuery wird auf diese Klasse gebunden und lauscht dem Click Event.
Falls eine Url aktiviert wird, läd jQuery die Url per Ajax Request, filtert dann evtl. ein spezielles Element (z.B. ein DIV und deren Unterelemente) und ersetzt dann ein vorhandenes Element gegen das neue Element.
Das ganze funktioniert dynamisch da die Url im Link ja  vorhanden ist.
Das Laden der Seite über den Link kann man am Schluss unterbinden (der Inhalt wurde ja bereits per Ajax aktualisiert).
Vorteil dieser Lösung ist.
Funktioniert Javascript aus irgendwelchen Gründen nicht lädt die Seite die Links ganz normal.
Gruß
Henning
« Letzte Änderung: 26.08.10 - 19:15:57 von heini_schwammerl »

 

Impressum Atnotes.de  -  Powered by Syslords Solutions  -  Datenschutz