Domanda

Ho un div che contiene le impostazioni e le opzioni su una pagina di gestione account.

$("#moreOptions").slideToggle('slow');
if ($("#moreOptions").is(":visible") == true) {
    $("#lnkMoreOpt").text("Less Options «")
}
else {
    $("#lnkMoreOpt").text("More Options »")
}

Il codice di cui sopra dovrebbe modificare il testo del / meno di collegamento più opzioni a seconda se è visibile o no, comunque sembra jQuery non tratta commutando come è invisibile / visibile.

Come posso implementare questa pur utilizzando la levetta funzioni?

È stato utile?

Soluzione

È necessario utilizzare la funzione di callback. Con il tempo l'istruzione if viene valutata l'slideToggle non avrà completato e si ottengono risultati non corretti.

$("#moreOptions").slideToggle('slow', callbackFn);

function callbackFn(){

     var $link = $("#lnkMoreOpt");

     $(this).is(":visible") ? $link.text("Less Options «") : $link.text("More Options »");


}

Altri suggerimenti

Credo che questo codice funziona

$('#element').toggle('slow', function() {
    if($(this).is(':hidden')) { 
        $(this).text('This element is hidden.');
    }
    else {
        $(this).text('This element is visible.');
    }
}); 

Io preferisco non usare funzioni distinte, perché quando una funzione non ha bisogno di essere usato due volte, è spreco di codice .. Credo che questo sia più facile da capire quando qualcuno viene ad esso ..

$("#moreOptions").slideToggle('slow', function(){
     var $link = $("#lnkMoreOpt");
     $(this).is(":visible") ? $link.text("Less Options «") : $link.text("More Options »");
});
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top