Näytä yksi teksti ja piilota muut

Anonyymi

Sivulla on monta radio buttonia, joiden perässä on näkymätön label-elementti. Kun käyttäjä klikkaa radio nappulaa, haluan sen perää ilmestyvän tekstin ja tekstin muiden radio nappuloiden perästä katoavan. Alla olevalla esimerkillä teksti ilmestyy näkyviin, mutta miten saan esim a1 ja a3 tekstin katoamaan samalla kun a2 muuttuu näkyväksi?

JS:
function show_a1(){ document.getElementById('a1').style.display = 'block'; }
function show_a2(){ document.getElementById('a2').style.display = 'block'; }
function show_a3(){ document.getElementById('a2').style.display = 'block'; }

HTML:
<input type='radio' onclick='show_a1();' >
<span id='a1' style='display: none;'>Joku teksti</span>

<input type='radio' onclick='show_a2();' >
<span id='a2' style='display: none;'>Joku teksti</span>

<input type='radio' onclick='show_a3();' >
<span id='a3' style='display: none;'>Joku teksti</span>

12

328

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Lisää funktiohin muiden elementtien piilotus.

    • Anonyymi

      Taas on tullut voimaan se sääntö että ei voi opastaa antamalla koodi esimerkin, mutta avauksessa se saa tämänkin säännön mukaan olla. Voi hyvä tavaton näitä suomi24 moderoijia, täysiä pölvästejä, ei mitään järkeä niitten tekemisissä.

      • Anonyymi

        Pitäisivät nyt hitto mistä tahansa säännöstä kiinni, ainakin kaksi vuorokautta, eihän tästä tule mitään että joka viestille luodaan omat säännöt. Tämä sivuston rassaaja kuubaan täältä sotkemasta. Kyllä ärsyttää tämä mielivaltainen ylläpito johon on pakko alistua, pistäkää ihmeessä joku vastaava sivusto pystyy, että täältä pääsee pois.


      • Anonyymi kirjoitti:

        Pitäisivät nyt hitto mistä tahansa säännöstä kiinni, ainakin kaksi vuorokautta, eihän tästä tule mitään että joka viestille luodaan omat säännöt. Tämä sivuston rassaaja kuubaan täältä sotkemasta. Kyllä ärsyttää tämä mielivaltainen ylläpito johon on pakko alistua, pistäkää ihmeessä joku vastaava sivusto pystyy, että täältä pääsee pois.

        Jaa, ihmettelinkin kun seikkaperäinen selitykseni koodeineen katosi kuin tuhka tuuleen!


      • Anonyymi
        0sm0 kirjoitti:

        Jaa, ihmettelinkin kun seikkaperäinen selitykseni koodeineen katosi kuin tuhka tuuleen!

        Arvaa montako minulta on viety, samalla tavalla, joskus saa olla, ja sitten taas ei. Ja juuri näissä, johon on aikaa tuhlannut eniten tuo tarpeeton poistaminen eniten vituttaa.

        Muuten nytkin harmitti kun palasin tähän ketjuun vain kopioidakseni sen testi sivulle aikeenani testata toimiiko, ja sitten huomasin että eihän sitä ole. Vaikutti hyvältä kohteelta opiskella JavaScript alkeita.


    • Anonyymi

      Jokaisen pitäisi nostaa "älämölön" näistä turhista poistoista, niin muutkin tulisi tietoiseksi ettei vaan kannata tuhlata aikaa oikeisiin ohjeisiin. Jos tästä uskaltaa vetää johtopäätöksiä niin avaus saa nykyään sisältää JavaScript kysymyksen ja kysymykseen liittyvän JavaScript koodin, mutta vastaus ei.

    • Anonyymi

      Jos tämmöinen on sääntöjen vastaista, niin ne säännöt pitäisi asettaa käyttäjien nähtäväksi.

    • Koodit voi laittaa esim JS-Fiddleen. Siellä on helppo testaillakin.

      Minä tein tällaisen: https://jsfiddle.net/v39u42Lt/
      Muokkasin vähän tuota HTML:ääkin (radioihin sama name-attribuutti, niin ovat samaa ryhmää (niin ilmeisesti halutaan) ja br:t väliin, niin radiot ei hypähtele, kun toinen valitaan ja teksti tulee väliin).

      Refaktoroin tekstin näyttämisen ja muiden piilottamisen funktioon showText(ind), jolle annetaan parametrinä se monesko inputti (ja span:ni) on kyseessä.

      • Anonyymi

        Sait sen näyttämään niiiiin vaikealta, että vaihdan kiinnostuksen kohdetta Pythoniin. Se 0sm0:n poistettu oli helpon näköinen juttu.


      • Anonyymi kirjoitti:

        Sait sen näyttämään niiiiin vaikealta, että vaihdan kiinnostuksen kohdetta Pythoniin. Se 0sm0:n poistettu oli helpon näköinen juttu.

        Olisko tämä helpomman näkönen: https://jsfiddle.net/xz5h2cr3/
        Mutta tässä tulee paljon toistoa. Varsinkin jos inputteja on vielä enemmän tai jopa niin ettet tiedä kuinka monta niitä tulee olemaan. Silloin silmukka on ainoa ratkaisu.

        Tuosta edellisestä ratkaisustani:
        - entries() on vähän niinkuin Pythonin enumerate, se antaa taulukosta (tai taulukkomaisesta objektista, jollainen document.querySelectorAll:n palaute on) samalla kertaa indeksin ja alkion.

        -ternääri-operaattori A?B:C vastaa rakennetta if (A) {B} else {C} ja se antaa sen arvon, kumpi suoritettiin A vai B.
        Eli
        (i===ind)?'inline-block':'none'
        on 'inline-block', jos i on yhtä kuin ind ja muuten se on 'none'.

        Kokeile vielä itse toteuttaa silmukkaratkaisu. Älä anna periksi!


      • Anonyymi
        minkkilaukku kirjoitti:

        Olisko tämä helpomman näkönen: https://jsfiddle.net/xz5h2cr3/
        Mutta tässä tulee paljon toistoa. Varsinkin jos inputteja on vielä enemmän tai jopa niin ettet tiedä kuinka monta niitä tulee olemaan. Silloin silmukka on ainoa ratkaisu.

        Tuosta edellisestä ratkaisustani:
        - entries() on vähän niinkuin Pythonin enumerate, se antaa taulukosta (tai taulukkomaisesta objektista, jollainen document.querySelectorAll:n palaute on) samalla kertaa indeksin ja alkion.

        -ternääri-operaattori A?B:C vastaa rakennetta if (A) {B} else {C} ja se antaa sen arvon, kumpi suoritettiin A vai B.
        Eli
        (i===ind)?'inline-block':'none'
        on 'inline-block', jos i on yhtä kuin ind ja muuten se on 'none'.

        Kokeile vielä itse toteuttaa silmukkaratkaisu. Älä anna periksi!

        No nyt se on jo ymmärrettävissä täysin, ja jotain tuotahan se turhaan poistettu 0sm0:n koodikin oli. Kopioin siitä huolimatta omalle sivulle, vaikka tuo testaaminen tuollakin onnistui.


    Ketjusta on poistettu 1 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. SDP jo 100 % suositumpi kuin persut

      Kertoo Hesarin uusin kannatuskysely. Demareiden kannatus on miltei tuplat verrattuna persuihinl. Suomen kansa ei selväst
      Maailman menoa
      94
      10681
    2. Voiko normaali ihminen ryhtyä vasemmistolaiseksi?

      Tätä jäin pohdiskelemaan.
      Maailman menoa
      247
      4586
    3. SDP haluaa 40 000 nettomaahanmuuttajaa

      SDP:n Suunnanmuutos-vaihtoehtobudjetissa, käy ilmi, että demarit itse asiassa vaativat räjähdysmäistä ”työperäisen” maah
      Maailman menoa
      163
      3953
    4. Orpo: Velkajarrua vastustavaa puoluetta vaikea ajatella hallitukseen

      No Minja Koskelan kommunistipuolue jäi ulos tuosta. Kaikki eduskuntapuolueet vasemmistoliittoa lukuun ottamatta sopivat
      Maailman menoa
      171
      3454
    5. PS ylivoimainen nousija myös HS:n gallupissa, SDP laskee taas

      https://www.verkkouutiset.fi/a/hs-gallup-sdpn-suosio-laskee-ps-nousussa/#0a7d2507 Ylivoimainen viime kuukausien nousija
      Maailman menoa
      72
      3272
    6. Valtavasti suomalaisia asunnottomina, mutta ei yhtään somalia

      tai muuta kehitysmaalaista. Mites tässä näin kävi? Tiedän hyvin, että esim. somaleita lentää ulos mm. Hekan asunnoista,
      Maailman menoa
      73
      3046
    7. Mikä tämä henkilö mahtaa touhuta Parkanossa

      Kamalaa https://www.ylasatakunta.fi/teksti/pirkanmaan-karajaoikeus-vangitsi-koiran-tappamisesta-epaillyn-6.68.127794.b58
      Parkano
      32
      2812
    8. Ikävä sinua mies

      Vuosia kuluu, mutta tunteet ei ole hävinnyt. Tasoittuneet toki, kun ei olla nähty. Järki palannut päähän kuitenkin. Se i
      Ikävä
      27
      2360
    9. Hienoa! Eduskunta luopui käteisen käytöstä

      Nyt tuo sama muutos pitää saada myös muuhun yhteiskuntaan. Käteistähän ei tarvitse tänä päivänä enää kuin rikolliset.
      Maailman menoa
      65
      1776
    10. Kiinnostaa - ei kiinnosta - kiinnostaapas

      Selittäkää hämmentyneelle miksi miehiä ei ikinä kiinnosta silloin, kun sitä olisi itsekin kiinnostunut? Sitten kun siirt
      Sinkut
      166
      1525
    Aihe