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
Webdesign: HTML/CSS, Responsive Design, Sass...
JQuery Click-Problem
Beitrag
<blockquote data-quote="Enigmon" data-source="post: 2514071" data-attributes="member: 6117"><p>Hallo Leute,</p><p></p><p>ich bin dabei einen Kreisel-Slider zu programmieren (3 "Bilder" sichtbar, Front gross die anderen klein).</p><p>Ich weiss, es gibt genügend Plugins, aber ich möchte auch das Prinzip dahinter erlernen/verstehen.</p><p>Nun zu meinem Problem. </p><p>Ich habe 3 Klassen <strong>"front", "left"</strong> und<strong> "right"</strong>. Wenn ich auf das <em>Bild / div</em> mit der Klasse left klicke, soll der Kreisel sich nach rechts drehen und die Klassen neu zugeordnet werden, d.h. das ehemalige linke <em>Bild / div</em> erhält die Klasse<strong> front </strong>und es wird die Klasse <strong>left</strong> entfernt usw.</p><p>Es funktioniert auch alles sehr gut. Im Firebug ist auch zu sehen das Klassen sich ändern.</p><p>Aber: </p><p>In dem Bsp. löst nur der Klick auf das <em>Bild / div </em>mit Klasse <strong>left</strong> ein Ereignis aus, d.h. es sollte nur immer das linke <em>Bild / div</em> eine Reaktion auslösen. Aber es lässt sich nur das <em>Bild / div</em> mit der originalen Anfangsklasse left anklicken egal ob sie nun <strong>front</strong> oder <strong>right</strong> als Klasse hat.</p><p></p><p>Wo könnte mein Denkfehler liegen?</p><p></p><p>Vielen Dank schon mal im Voraus</p><p>Thomas</p><p></p><p>Hier der Quellcode (Ein Bild sagt mehr als viele Worte):</p><p>[html]<!DOCTYPE html></p><p><html lang="de-DE"></p><p><head></p><p><meta charset="UTF-8"></p><p><title>Kreisel-Slider</title></p><p><!--[if lt IE 9]></p><p> <script src="https://cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.2/html5shiv.js"></script></p><p><![endif]--></p><p><script src="http://code.jquery.com/jquery-latest.js"></script></p><p><script type="text/javascript" src="js/jquery-2.1.0.min.js"></script></p><p><script src="js/JQuery-Karusell-Slider.js"></script></p><p><style></p><p>header, section, footer, aside, nav, main, article, figure {</p><p> display: block;</p><p>}</p><p></p><p>#karusell-slider{</p><p> width: 960px; height:400px; overflow: hidden;</p><p> position: relative;</p><p> margin: 50px auto 20px;</p><p> </p><p>}</p><p>#karusell-slider img{</p><p> border: 1px solid black;</p><p> </p><p>}</p><p>#karusell-slider>div{</p><p> /*background: rgb(127,127,127);*/</p><p> border: 1px solid black;</p><p>}</p><p>.front{</p><p> position: absolute; left: 180px;</p><p> width: 600px; height: 300px; z-index: 50; margin: 0px auto 10px; top: 30px;</p><p> background: rgb(65,76,170);</p><p>}</p><p>.left{</p><p> position: absolute; left: 0;</p><p> width: 400px; height:200px; z-index: 30; float: left;</p><p> background: rgb(255,224,93);</p><p>}</p><p>.right{</p><p> position: absolute; right: 0;</p><p> width: 400px; height:200px; z-index: 30; float: right;</p><p> background: rgb(92,185,59);</p><p>}</p><p>.other{</p><p> display: none;</p><p>}</p><p></style></p><p></head></p><p></p><p><body></p><p><header></header></p><p><nav></nav></p><p><section></p><p><div id="karusell-slider"></p><p> <div id="ks_1" class="front" ><b>Ich bin jetzt front-Klasse</b></div></p><p> <div id="ks_2" class="left" ><b>Ich bin jetzt left-Klasse</b></div></p><p> <div id="ks_4" class="right"><b>Ich bin jetzt right-Klasse</b></div></p><p></div></p><p><div id="Kontrolle">Kontrolle: </div></p><p></section></p><p><footer></footer></p><p></body></p><p></p><p></html> [/html]</p><p></p><p>hier die JS- Datei:</p><p>[code=JavaScript]</p><p>$(document).ready(function(){</p><p> </p><p> $(".left").click(function(){</p><p> $("#Kontrolle").append("LeftClick; ");</p><p> rotateRight();</p><p> });</p><p> </p><p> </p><p> $(".right").click(function(){</p><p> $("#Kontrolle").append("RightClick; ");</p><p> });</p><p> </p><p> $(".front").click(function(){</p><p> $("#Kontrolle").append("FrontClick; ");</p><p> });</p><p> </p><p>});</p><p></p><p>function rotateRight(){</p><p> </p><p> $( ".left" ).animate({</p><p> width: "600px",</p><p> height: "300px",</p><p> left: "+=180",</p><p> top: "+=30",</p><p> }, 500, "swing",function() {</p><p> $(this).css('z-index', 50);</p><p> $(this).addClass("front");</p><p> $(this).removeClass("left");</p><p> $(this).append("Ich bin jetzt "+$(this).attr('class')+"-Klasse");</p><p> });</p><p> </p><p> $(".front").animate({</p><p> width: "400px",</p><p> height: "200px",</p><p> left: "+=380",</p><p> top: "-=30",</p><p> },500,function() {</p><p> $(this).css('z-index', 30);</p><p> $(this).addClass("right");</p><p> $(this).removeClass("front");</p><p> $(this).append("Ich bin jetzt "+$(this).attr('class')+"-Klasse");</p><p> });</p><p> </p><p> $(".right").animate({</p><p> left: "0",</p><p> },500,"swing",function(){</p><p> $(this).css('z-index', 30);</p><p> $(this).addClass("left");</p><p> $(this).removeClass("right");</p><p> $(this).append("Ich bin jetzt "+$(this).attr('class')+"-Klasse");</p><p> });</p><p> </p><p>}</p><p></p><p>[/code]</p></blockquote><p></p>
[QUOTE="Enigmon, post: 2514071, member: 6117"] Hallo Leute, ich bin dabei einen Kreisel-Slider zu programmieren (3 "Bilder" sichtbar, Front gross die anderen klein). Ich weiss, es gibt genügend Plugins, aber ich möchte auch das Prinzip dahinter erlernen/verstehen. Nun zu meinem Problem. Ich habe 3 Klassen [B]"front", "left"[/B] und[B] "right"[/B]. Wenn ich auf das [I]Bild / div[/I] mit der Klasse left klicke, soll der Kreisel sich nach rechts drehen und die Klassen neu zugeordnet werden, d.h. das ehemalige linke [I]Bild / div[/I] erhält die Klasse[B] front [/B]und es wird die Klasse [B]left[/B] entfernt usw. Es funktioniert auch alles sehr gut. Im Firebug ist auch zu sehen das Klassen sich ändern. Aber: In dem Bsp. löst nur der Klick auf das [I]Bild / div [/I]mit Klasse [B]left[/B] ein Ereignis aus, d.h. es sollte nur immer das linke [I]Bild / div[/I] eine Reaktion auslösen. Aber es lässt sich nur das [I]Bild / div[/I] mit der originalen Anfangsklasse left anklicken egal ob sie nun [B]front[/B] oder [B]right[/B] als Klasse hat. Wo könnte mein Denkfehler liegen? Vielen Dank schon mal im Voraus Thomas Hier der Quellcode (Ein Bild sagt mehr als viele Worte): [html]<!DOCTYPE html> <html lang="de-DE"> <head> <meta charset="UTF-8"> <title>Kreisel-Slider</title> <!--[if lt IE 9]> <script src="https://cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.2/html5shiv.js"></script> <![endif]--> <script src="http://code.jquery.com/jquery-latest.js"></script> <script type="text/javascript" src="js/jquery-2.1.0.min.js"></script> <script src="js/JQuery-Karusell-Slider.js"></script> <style> header, section, footer, aside, nav, main, article, figure { display: block; } #karusell-slider{ width: 960px; height:400px; overflow: hidden; position: relative; margin: 50px auto 20px; } #karusell-slider img{ border: 1px solid black; } #karusell-slider>div{ /*background: rgb(127,127,127);*/ border: 1px solid black; } .front{ position: absolute; left: 180px; width: 600px; height: 300px; z-index: 50; margin: 0px auto 10px; top: 30px; background: rgb(65,76,170); } .left{ position: absolute; left: 0; width: 400px; height:200px; z-index: 30; float: left; background: rgb(255,224,93); } .right{ position: absolute; right: 0; width: 400px; height:200px; z-index: 30; float: right; background: rgb(92,185,59); } .other{ display: none; } </style> </head> <body> <header></header> <nav></nav> <section> <div id="karusell-slider"> <div id="ks_1" class="front" ><b>Ich bin jetzt front-Klasse</b></div> <div id="ks_2" class="left" ><b>Ich bin jetzt left-Klasse</b></div> <div id="ks_4" class="right"><b>Ich bin jetzt right-Klasse</b></div> </div> <div id="Kontrolle">Kontrolle: </div> </section> <footer></footer> </body> </html> [/html] hier die JS- Datei: [code=JavaScript] $(document).ready(function(){ $(".left").click(function(){ $("#Kontrolle").append("LeftClick; "); rotateRight(); }); $(".right").click(function(){ $("#Kontrolle").append("RightClick; "); }); $(".front").click(function(){ $("#Kontrolle").append("FrontClick; "); }); }); function rotateRight(){ $( ".left" ).animate({ width: "600px", height: "300px", left: "+=180", top: "+=30", }, 500, "swing",function() { $(this).css('z-index', 50); $(this).addClass("front"); $(this).removeClass("left"); $(this).append("Ich bin jetzt "+$(this).attr('class')+"-Klasse"); }); $(".front").animate({ width: "400px", height: "200px", left: "+=380", top: "-=30", },500,function() { $(this).css('z-index', 30); $(this).addClass("right"); $(this).removeClass("front"); $(this).append("Ich bin jetzt "+$(this).attr('class')+"-Klasse"); }); $(".right").animate({ left: "0", },500,"swing",function(){ $(this).css('z-index', 30); $(this).addClass("left"); $(this).removeClass("right"); $(this).append("Ich bin jetzt "+$(this).attr('class')+"-Klasse"); }); } [/code] [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 5, ▼ = 2 und ■ = 7, was ist ▲ × ▼ + ■?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
Webdesign: HTML/CSS, Responsive Design, Sass...
JQuery Click-Problem
Oben