[TYPO3-german] jQuery-Bibliothek in eigenen Extensions

Sven Wappler mailinglists at wapplersystems.de
Wed May 8 15:48:39 CEST 2013


Hallo Peter,

ich als Webentwickler bin der Meinung, auf das Mitliefern des
jQuery-Cores zu verzichten, oder wenn überhaupt dann einfach optional
über eine Template-Konstante einschaltbar zu machen.
Der jQuery-Core sollte nicht mitgeliefert werden, weil meistens die
Versionen schnell veralten und man irgendwann dann sowieso den Core
manuell einbauen muss, weil der Extension-Entwickler nicht aktualisiert
(warum sollte er auch jeden Monat).
Außerdem muss man sich als Administrator sowieso um die Kompatibilität
der einzelnen Skripte kümmern. Und so kompliziert ist der Einbau des
Cores mit ein wenig TypoScript nun auch wieder nicht.
Sollte die eigene Extension jQuery Java-Scripte benötigen, dann einfach
in den Footer damit. Dort können sie immer geladen werden, egal ob der
Core im Header oder im Footer geladen wird.

Grüße, Sven


Am 08.05.2013 15:04, schrieb Peter Linzenkirchner:
> Hallo!
> 
> ich habe in der Extension-Entwicklung ein Problem mit dem Einbinden von jQuery, das generellerer Natur ist, deshalb würde ich das gerne diskutieren. 
> 
> Viele Extensions benötigen jQuery und binden die Bibliothek auch ein. Sobald man mehr als eine Extension installiert, wird die Bibliothek also doppelt installiert und man bekommt JavaScript-Fehler. Meist kann man das Einbinden der Bibliothek per Typoscript abschalten, z. B. bei Powermail über dieses Typoscript: 
> 
> page {
> 	includeJSFooterlibs {
> 		powermailJQuery >
> 		powermailJQuery.external >
> 	}
> }
> 
> Man kann also theoretisch das Einbinden der Bibliothek in allen Extensions abschalten und nur in einer drin lassen. Aber in dem Fall gibt es zwei Probleme: 
> 
> 1. Header / Footer
> Ein Teil der Extensions bindet das eigene JavaScript bzw. die jQuery-Plugins im Header ein. Wenn man jQuery selbst im Footer einbindet, bekommt man entsprechende Fehlermeldungen, dass jQuery nicht gefunden wird. 
> Man muss 
> - entweder eine eigene jQuery-Bibliothek in den Head einbinden, 
> - oder dafür sorgen, dass alle Extensions ihre jQuery-Plugins in den Footer legen. 
> 
> 2. allgemeines Reihenfolgeproblem
> includeJSFooterlibs scheint die JavaScript-Bibliothek nicht in alphabetischer Reihenfolge zu laden sondern in der Lade-Reihenfolge der Extensions. Das kann zu kuriosen Zufällen führen: mal ist jQuery an erster Stelle, mal nicht ... mal wirft es Fehler, mal nicht. und es reicht, eine Extension kurz zu deinstallieren und schon geht es nicht mehr. 
> 
> ---
> 
> gibt es da Lösungen, Ideen? Wie gehe ich in einer eigenen Extension am besten damit um? 
> 
> Ich binde momentan meine JavaScript-Bibliothek so ein: 
> $GLOBALS['TSFE']->pSetup['includeJSFooterlibs.'][$this->extKey.'_1']  ... 
> das erscheint mir zunehmend als schlechte Idee. 
> 
> Alex macht es in Powermail so: 
> 
> page {
> 	includeJSFooterlibs {
> 		....
> 	}
> }
> 
> das ist flexibler denke ich, weil man einfach den Abschnitt aus dem Extension-Setup kopieren, erweitern und dann ins page-setup einbauen kann. Aber es ist nicht benutzerfreundlich ... 
> 
> Danke
> Peter
> 
> 
> 
> --
> Xing: http://www.xing.com/profile/Peter_Linzenkirchner
> Web: http://www.typo3-lisardo.de
> Facebook: http://tinyurl.com/lisardo-multimedia
> 
> _______________________________________________
> TYPO3-german mailing list
> TYPO3-german at lists.typo3.org
> http://lists.typo3.org/cgi-bin/mailman/listinfo/typo3-german
> 


-- 
WapplerSystems: http://www.wapplersystems.de
T3Yaml Template: http://t3yaml.de
T3bootstraptv: http://t3bootstraptv.de
Xing: https://www.xing.com/profile/Sven_Wappler
Geeklist: http://geekli.st/svewap
Twitter: https://twitter.com/WapplerSystems


More information about the TYPO3-german mailing list