PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Overlay springt
Beitrag
<blockquote data-quote="mindraper" data-source="post: 1960481" data-attributes="member: 115163"><p><strong>AW: Overlay springt</strong></p><p></p><p>hi.</p><p></p><p>@tr3icio: wer lesen kann ist klar im vorteil. deine antwort ist ziemlich an der eigentlichen frage vorbei.</p><p></p><p>@thorstenschmitt:</p><p>ich nehme an, dass du das overlay mittels eines links schliesst, korrekt? und im href-attribut des links ist eine raute notiert? dann ist es ganz einfach.</p><p></p><p>HTML (des overlays)</p><p>[HTML]</p><p><div id="overlay"></p><p> <a href="#" id="close_overlay">Schliessen</a></p><p> </p><p> <!-- ab hier dann die restlichen inhalte --></p><p></p><p></div></p><p>[/HTML]JAVASCRIPT</p><p>[PHP]</p><p>function close_overlay( event ){</p><p> event.preventDefault(); // standardverhalten des browsers unterbinden</p><p> event.stopPropagation(); // durchreichen des events verhindern</p><p></p><p> $( event.target ).parent().fadeOut( 500 );</p><p>}</p><p></p><p>$( '#close_overlay' ).bind( 'click', close_overlay );</p><p></p><p>// bzw. auch machbar (alternativ!):</p><p>// $( '#close_overlay' ).click( close_overlay );</p><p>[/PHP]ERKLÄRUNG</p><p>wenn du auf einen link ( bzw. egal wo auf einer page ) klickst, registriert der browser ein event, also ein ereignis. diese events können abgefangen und ausgewertet werden, sofern für das entsprechende event ein sog. eventlistener registriert wurde. dass passiert bei jQuery mittels bind() ( die kurzformen wie z. b. "click()" nutzen intern ebenfalls die bind()-methode von jQuery ).</p><p>wenn ein event normalerweise ein bestimmtes browserverhalten triggert, dann nennt man dieses browserverhalten das "standardverhalten". ein klick auf einen link beispielsweise ruft das standardverhalten "rufe die seite mit der im href-attribut angegebenen url auf" auf. in deinem fall möchtest du aber gerade nicht, dass der browser die angegebene seite bzw. den ankerverweis lädt. du unterdrückst das standardverhalten in diesem fall mit "event.preventDefault()". genau das gleiche kannst du auch machen, wenn du beispielsweise ein formular via ajax verschicken möchtest.</p><p></p><p>wichtig ist allerdings auch die zweite zeile "event.stopPropagation()". grund ist folgender: </p><p>( fast ) jedes event hat eine sog. propagate- und bubbling-phase. das bedeutet, dass ein event auf einem kindknoten eines dom-elements von dessen elternknoten ebenfalls registriert wird. schematisch könnte man das so darstellen:</p><p></p><p>DIV</p><p>└> ANode</p><p> ......└>TEXTNode</p><p></p><p>so sieht dein browser dein HTMLkonstrukt. streng genommen klickst du auch nicht auf das a-element, sondern auf den TEXTNode. in der propagate-phase des events durchläuft das event diese dom-struktur folgendermaßen:</p><p></p><p>DIV > ANode > TEXTNode</p><p></p><p>anschließend kommt die bubbling-phase. dabei durchläuft das event die dom-struktur rückwärts, also:</p><p></p><p>TEXTNode > ANode > DIV</p><p></p><p>sicherheitshalber solltest du die propagate- und bubbling-phase eines events dessen standardverhalten du unterdrücken willst immer mit unterdrücken. je nach der dom-struktur kann es dir nämlich andernfalls geschehen, dass das event auf der höhe des angeklickten elements nicht ausführt, dafür aber auf der nächst höheren ebene innerhalb der dom-struktur.</p><p></p><p>hoffe das hilft</p></blockquote><p></p>
[QUOTE="mindraper, post: 1960481, member: 115163"] [b]AW: Overlay springt[/b] hi. @tr3icio: wer lesen kann ist klar im vorteil. deine antwort ist ziemlich an der eigentlichen frage vorbei. @thorstenschmitt: ich nehme an, dass du das overlay mittels eines links schliesst, korrekt? und im href-attribut des links ist eine raute notiert? dann ist es ganz einfach. HTML (des overlays) [HTML] <div id="overlay"> <a href="#" id="close_overlay">Schliessen</a> <!-- ab hier dann die restlichen inhalte --> </div> [/HTML]JAVASCRIPT [PHP] function close_overlay( event ){ event.preventDefault(); // standardverhalten des browsers unterbinden event.stopPropagation(); // durchreichen des events verhindern $( event.target ).parent().fadeOut( 500 ); } $( '#close_overlay' ).bind( 'click', close_overlay ); // bzw. auch machbar (alternativ!): // $( '#close_overlay' ).click( close_overlay ); [/PHP]ERKLÄRUNG wenn du auf einen link ( bzw. egal wo auf einer page ) klickst, registriert der browser ein event, also ein ereignis. diese events können abgefangen und ausgewertet werden, sofern für das entsprechende event ein sog. eventlistener registriert wurde. dass passiert bei jQuery mittels bind() ( die kurzformen wie z. b. "click()" nutzen intern ebenfalls die bind()-methode von jQuery ). wenn ein event normalerweise ein bestimmtes browserverhalten triggert, dann nennt man dieses browserverhalten das "standardverhalten". ein klick auf einen link beispielsweise ruft das standardverhalten "rufe die seite mit der im href-attribut angegebenen url auf" auf. in deinem fall möchtest du aber gerade nicht, dass der browser die angegebene seite bzw. den ankerverweis lädt. du unterdrückst das standardverhalten in diesem fall mit "event.preventDefault()". genau das gleiche kannst du auch machen, wenn du beispielsweise ein formular via ajax verschicken möchtest. wichtig ist allerdings auch die zweite zeile "event.stopPropagation()". grund ist folgender: ( fast ) jedes event hat eine sog. propagate- und bubbling-phase. das bedeutet, dass ein event auf einem kindknoten eines dom-elements von dessen elternknoten ebenfalls registriert wird. schematisch könnte man das so darstellen: DIV └> ANode ......└>TEXTNode so sieht dein browser dein HTMLkonstrukt. streng genommen klickst du auch nicht auf das a-element, sondern auf den TEXTNode. in der propagate-phase des events durchläuft das event diese dom-struktur folgendermaßen: DIV > ANode > TEXTNode anschließend kommt die bubbling-phase. dabei durchläuft das event die dom-struktur rückwärts, also: TEXTNode > ANode > DIV sicherheitshalber solltest du die propagate- und bubbling-phase eines events dessen standardverhalten du unterdrücken willst immer mit unterdrücken. je nach der dom-struktur kann es dir nämlich andernfalls geschehen, dass das event auf der höhe des angeklickten elements nicht ausführt, dafür aber auf der nächst höheren ebene innerhalb der dom-struktur. hoffe das hilft [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ★ = 12, ◇ = 4 und die Hälfte von ★ zu ◇ addiert wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Overlay springt
Oben