Diskuze: Onclick - vracení na původní stav
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 11 zpráv z 11.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Pokud se to má být jen tam a zpět, doporučuji mu přiřadit vždy
třídu.
Tzn. třeba .active{ left: 200px; }
Nemyslím, že při kliknutí změní pozici a pak zpět, potřebuji aby tam chvíli zůstal a až uživatel klikne podruhé tak aby se vrátil zpět.
Nedělám v JS tak ti to napíšu obecně, doufám že to pochopíš
var atribut=1;
if(atribut==1)//je jedno jak to budeš mít
{
atribut=0;
posunuti o danou hodnotu;
}
else
{
atribut=1;
posunuti zpet o danou hodnotu;
}
A pak jen budeš volat v onclicku daný if a máš to jen ten atribut musíš definovat
jako globální se mi zdá, nebo jak to tam je
Však to jsem myslel, popíšu to v jQuery :
$('selektor').click(function(){
$(this).toggleClass('active');
});
Pokud to chápu správně tak chceš něco velmi jednoduchého skrze
JQuery.
Stačí když při kliknutí na daný prvek například do proměnné clicked
uložíš 1 a když klikne podruhé kontroluješ jestli už uživatel klikl. A
dám příklad u menu: Poprvé klikne posuneš prvek a 200px doprava a uložíš
si do proměnné clicked 1. A když klikne, zkontroluješ jestli je proměnná
clicked 1 a pokud ano posuneš to o 200px doleva, pokud ne posuň prvek o 200px
doleva.
var element = document.querySelector('#elem');
element.addEventListener('click', function() {
var isActive = this.className.match(/active/);
if (isActive) {
this.className = this.className.replace(/ ?active/, '');
} else {
this.className += ' active';
}
}, false);
Nebo pro víc elementů:
var clickHandler = function() {
var isActive = this.className.match(/active/);
if (isActive) {
this.className = this.className.replace(/ ?active/, '');
} else {
this.className += ' active';
}
};
var elements = Array.prototype.slice.call(document.querySelectorAll('#elem'), 0);
elements.forEach(function(element) {
element.addEventListener('click', clickHandler, false);
});
Jestli jsem dobře pochopil tak, pokud chceš JS bez JQuery, tak nejjednodušší to bude takto:
HTML:
<div id="posunutyPredmet" onClick="posun()"></div>
JS:
var pozice = 0;
function posun() {
if (pozice==0) {
pozice = 1;
Posunuti o danou hodnotu
}
else {
pozice = 0;
Posun na defaultni hodnotu
}
}
Jak psal Drahomír Hanák
var element = document.querySelector('#elem');
element.addEventListener('click', function() {
var isActive = this.className.match(/active/);
if (isActive) {
this.className = this.className.replace(/ ?active/, '');
} else {
this.className += ' active';
}
}, false);
Jojo, jen jsem si říkal, že tak to bude více přehlednější...
Zobrazeno 11 zpráv z 11.