php.de

Zurück   php.de > Webentwicklung > JavaScript, Ajax und mehr

JavaScript, Ajax und mehr dynamisches Scripten und Interaktion auf Clientebene

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 21.06.2010, 07:06  
Neuer Benutzer
 
Registriert seit: 25.07.2009
Beiträge: 13
PHP-Kenntnisse:
Fortgeschritten
tino91 befindet sich auf einem aufstrebenden Ast
Standard jQuery mehrfach auf selben veränderten Element

Hallo @ all,

ich habe ein Problem mit einer jQuery-Funktion. Ziel ist es einen Kommentar hervorzuheben. Dabei habe ich ein Bild mit einem #-Link ausgestattet, so dass mir die nötigen Daten übergeben werden.

Die Funktionen sind bis auf die Namen fast Baugleich und funktionieren jedoch je nur einmal.

PHP-Code:
                        //////////////////////////////////////////
                        // Notiz markieren / nicht markieren
                        //////////////////////////////////////////                    
                        
$(".marknotiz").click(function(e) {
                            
e.preventDefault();
                            var 
commentID = $(this).attr("title");
    
                            $(
this).attr("class","unmarknotiz");
                            $(
this).attr("href","#");
                                                    
                            $(
'.notiz-' commentID).load("jsaction.php?action=markcomment&id=" commentID, function(responsestatusxhr){
                                $(
this).attr("src","img/msel.gif");
                            });    
                                                                                
                        });        
                        
                        
// Eventuell muss das HREF noch durch eine Route ersetzt werden, damit er das merkt!"!!!! (Gedanke am Abend))"
                        
                        
$(".unmarknotiz").click(function(e) {
                            
e.preventDefault();
                            var 
commentID = $(this).attr("title");
    
                            $(
this).attr("class","marknotiz");
                            $(
this).attr("href","#");
                                                    
                            $(
'.notiz-' commentID).load("jsaction.php?action=unmarkcomment&id=" commentID, function(responsestatusxhr){
                                $(
this).attr("src","img/mnosel.gif");
                            });    
                                                                                
                        }); 

Das dazu genutze HTML-Element sieht so aus:

PHP-Code:
<a href="#" title="845" class="marknotiz"><img class="notiz-845" src="img/mnosel.gif" border="0"></a
Es klapp auch je einmal, also:
marknotiz -> unmarknotiz, oder
unmarknotiz -> marknotiz

Jedoch klapp es nie zurück:
marknotiz -> unmarknotiz -> marknotiz, oder
unmarknotiz -> marknotiz -> unmarknotiz

Was mache ich falsch.

Gruß

tino91

Geändert von tino91 (21.06.2010 um 07:14 Uhr).
tino91 ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 21.06.2010, 07:08  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

So auf die Schnelle würde ich sagen, Du löschst die alte Klasse nicht. Dadurch wird bei jedem weiteren Klick jede Funktion nacheinander ausgeführt.
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch ist offline   Mit Zitat antworten
Alt 21.06.2010, 07:36  
Neuer Benutzer
 
Registriert seit: 25.07.2009
Beiträge: 13
PHP-Kenntnisse:
Fortgeschritten
tino91 befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Zitat von nikosch Beitrag anzeigen
So auf die Schnelle würde ich sagen, Du löschst die alte Klasse nicht. Dadurch wird bei jedem weiteren Klick jede Funktion nacheinander ausgeführt.
Du meinst damit das der Link

PHP-Code:
<a href="#" title="845" class="marknotiz">... 
sich nicht zu

PHP-Code:
<a href="#" title="845" class="unmarknotiz">... 
ändert? Da muss ich leider ein Kontra einlegen. Der Link wird mir im Firefox nach dem Klick im Quelltext korrekt verändert angezeigt.

Sollte ich da an irgendwas vorbei rauschen, würde ich mich auf Klärung freuen.

Gruß und danke für die rasche Antwort.

tino91

// Edit:

Oder meintest du das, folgendes noch (nach?) dem ändern in die Funktion muss: $(".marknotiz").removeClass("marknotiz");

Geändert von tino91 (21.06.2010 um 07:44 Uhr).
tino91 ist offline   Mit Zitat antworten
Alt 21.06.2010, 08:22  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard



PHP-Code:
<a href="#" title="845" class="marknotiz unmarknotiz"
Steht eigentlich oben, was ich meine.

Zitat:
Oder meintest du das, folgendes noch (nach?) dem ändern in die Funktion muss: $(".marknotiz").removeClass("marknotiz");
Das wäre meine Vermutung.
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch ist offline   Mit Zitat antworten
Alt 21.06.2010, 08:22  
Erfahrener Benutzer
 
Registriert seit: 28.05.2008
Beiträge: 2.094
PHP-Kenntnisse:
Fortgeschritten
rudygotya ist einfach richtig nettrudygotya ist einfach richtig nettrudygotya ist einfach richtig nettrudygotya ist einfach richtig nettrudygotya ist einfach richtig nett
Standard

Entweder löst man das mit einer gemeinsamen Klasse, so dass du in dem Objekt einfach nen Schalter hast und kann das durch einen event bind lösen oder per $.live. Du solltest dir trotzdem mal addClass / removeClass ansehen.
__________________
++++ Wieder einer ins Netz gegangen: Phishers Fritz zufrieden ++++
Blog
rudygotya ist offline   Mit Zitat antworten
Alt 21.06.2010, 15:34  
Neuer Benutzer
 
Registriert seit: 25.07.2009
Beiträge: 13
PHP-Kenntnisse:
Fortgeschritten
tino91 befindet sich auf einem aufstrebenden Ast
Standard

Habe mit bind und unbind versucht zu arbeiten, brachte kein Erfolg. addClass und removeClass sind nun erstmal nicht mehr notwendig, ich habe eine entsprechende Funktion geschrieben, die nun beide Funktionen "marknotiz" und "unmarknotiz" entsprechend vereint. Dank if / else, ist das nun kein Problem mehr. Danke für die Tipps am frühen morgen
tino91 ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
jQuery findet Element nicht ByStones JavaScript, Ajax und mehr 8 11.06.2010 14:03
Element erstellen, in Quelltext einfügen und auf dieses zugreifen können R4v3r JavaScript, Ajax und mehr 8 18.12.2009 11:33
[Erledigt] Mehrfach selben datensatz in Datenbank vikt0r PHP Tipps 2009 11 14.11.2009 15:29

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
jquery click doppelt, jquery click mehrfach, jquery funktion mehrmals aufrufen, jquery mehrfach, jquery doppelt, jquery bind click mehrfacher aufruf, http://www.php.de/javascript-ajax-und-mehr/69085-jquery-mehrfach-auf-selben-veraenderten-element.html, jquery load mehrmals, jquery .click doppelt, jquery mehrmals click, jquery bind mehrfach, jquery event mehrmals, .click jquery 2mal, jquery veränderte elemente, jquery funktion mehrfach, jquery mehrfach click, jquery function mehrmals, jquery click nur einmal, jquery click mehrmals, jquery funktion mehrmals ausführen

Alle Zeitangaben in WEZ +2. Es ist jetzt 08:49 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum