Pereiti prie turinio

JavaScript onclick klausimas


Rekomenduojami pranešimai

Sveiki,

 

Pirmą kartą rašau šiame forume, tai nemuškit jei kas ne taip :)

 

Užgriuvo atrodo paprastas klausimas, kurio nesugebu išspręsti. rašau JS atskirame faile. Paėmęs tam tikro elemento ID darau onclick. Žodžiu šis pvz veikia puikiai:

var logo = document.getElementById("logo");

logo.onclick = function () {
    window.location.href = '/'
};

 

Bet, niekaip nesuvokiu, kaip padaryti jei aš turiu keletą skirtingų ID kuriuos onclick turėtų pasiųsti ten pat, pvz:


var logo = document.getElementById("logo");
var photo = document.getElementById("photo");

// čia turėtų būti kaip nors taip, tik nesuvokiu kaip:
var abu = logo && photo;

abu.onclick = function () {
   window.location.href = '/'
};

 

Ar taip paprastai šitas reikalas nepavyks ir reikia rašyt abi onclick funkcijas atskirai su ta pačia lokacija?

 

Dėkoju už pagalbą.

 

Exo

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Sveiki,

 

Pirmą kartą rašau šiame forume, tai nemuškit jei kas ne taip :)

 

Užgriuvo atrodo paprastas klausimas, kurio nesugebu išspręsti. rašau JS atskirame faile. Paėmęs tam tikro elemento ID darau onclick. Žodžiu šis pvz veikia puikiai:

var logo = document.getElementById("logo");

logo.onclick = function () {
    window.location.href = '/'
};

 

Bet, niekaip nesuvokiu, kaip padaryti jei aš turiu keletą skirtingų ID kuriuos onclick turėtų pasiųsti ten pat, pvz:


var logo = document.getElementById("logo");
var photo = document.getElementById("photo");

// čia turėtų būti kaip nors taip, tik nesuvokiu kaip:
var abu = logo && photo;

abu.onclick = function () {
   window.location.href = '/'
};

 

Ar taip paprastai šitas reikalas nepavyks ir reikia rašyt abi onclick funkcijas atskirai su ta pačia lokacija?

 

Dėkoju už pagalbą.

 

Exo

 

Nebandžiau nei vieno varianto, bet aš bandyčiau kažką tokio.

 


var logo = document.getElementById("logo");
var photo = document.getElementById("photo");

logo.onclick = onClickLocation();
photo.onclick = onClickLocation();

function onClickLocation () {

   window.location.href = '/';

}

arba

onClickLocation("logo");
onClickLocation("photo)"

function onClickLocation ( id ) {
   var element = document.getElementById(id);
   element.onclick = function () {
       window.location.href = '/'
   };

}

Nuoroda į pranešimą
Dalintis kituose puslapiuose


var logo = document.getElementById("logo");
var photo = document.getElementById("photo");

logo.onclick = onClickLocation(); // blogai!!
photo.onclick = onClickLocation(); // blogai!!


logo.onclick = onClickLocation; // gerai
photo.onclick = onClickLocation; // gerai

 

 

() reiškia funkcijos kvietimą – tada onclick'ui prsikirtų ne pačią funkciją, o tai, ką ji grąžina (kadangi nieko negrąžina – tai undefined.

 

Aišku, dar geriau būtų naudoti addEventListener https://developer.mozilla.org/en-US/docs/Web/API/EventTarget.addEventListener . Tik jei nori su juo palaikyti IE 8 ir žemesnius, reikia naudoti MS'o nuosavą attachEvent().

Nuoroda į pranešimą
Dalintis kituose puslapiuose


var logo = document.getElementById("logo");
var photo = document.getElementById("photo");

logo.onclick = onClickLocation(); // blogai!!
photo.onclick = onClickLocation(); // blogai!!


logo.onclick = onClickLocation; // gerai
photo.onclick = onClickLocation; // gerai

 

 

() reiškia funkcijos kvietimą – tada onclick'ui prsikirtų ne pačią funkciją, o tai, ką ji grąžina (kadangi nieko negrąžina – tai undefined.

 

Aišku, dar geriau būtų naudoti addEventListener https://developer.mozilla.org/en-US/docs/Web/API/EventTarget.addEventListener . Tik jei nori su juo palaikyti IE 8 ir žemesnius, reikia naudoti MS'o nuosavą attachEvent().

 

Dėkui, kad pataisei, nelabai įsigilinęs į JS :)

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...