Miksi tämä scripti ei toimi?

Avustanne kiittäen...

Hei,

en saa tätä scriptiä millään toimimaan, jos joku voi auttaa niin kiitos...

Kirjoitettu esimerkkitapauksesta, joka löytyy netistä...tutoriaaleista...ei vain toimi.

Antaa ainakin seuraavan virheilmoituksen:

Virhe:
Rivi: 57
Merkki:1, arvoksi on annettava objekti.
Koodi: 0

* Virheellinen riviviittaus 57:



.................................................



Javascript slide show testi






play slide show
pause
previous
next

6

3842

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Ron Jeremy

      Rumahkoa koodia tuo oli -- ja antiikkinen tapa tehdä kuvaslideshow -- mutta tuossa skriptissäsi oli tyypillinen virhe (switchImage funktiossa) kun välitetään parametrina setTimeout() metodille sellainen funktio jolle välitetään myös parametri.

      Parasta on välittää argumenttina anonyymifunktio joka sitten kutsuu haluttua funktiota näin:

      timerID = setTimeout (function() {switchImage(place); }, interval);


      switchImage funktiomäärittelystä puuttui myös päättävä }. Tässä koko koodi (vähän siistin sitä samalla).




      Javascript slide show testi


      var interval = 1500;
      var random_display = 0;
      var imageDir = "";
      var imageNum = 0;

      imageArray = new Array();
      imageArray[imageNum ] = new imageItem(imageDir "Etusivu.jpg");
      imageArray[imageNum ] = new imageItem(imageDir "Etusivu.gif");
      imageArray[imageNum ] = new imageItem(imageDir "Etusivu.png");
      imageArray[imageNum ] = new imageItem(imageDir "Etusivu.jpg");
      imageArray[imageNum ] = new imageItem(imageDir "Etusivu.png");
      var totalImages = imageArray.length;

      function imageItem(image_location) {
      this.image_item = new Image();
      this.image_item.src = image_location;
      }

      function get_ImageItemLocation(imageObj) {
      return imageObj.image_item.src;
      }

      function randNum(x, y) {
      var range = y - x 1;
      return Math.floor(Math.random() * range) x;
      }

      function getNextImage() {
      if (random_display) {
      imageNum = randNum (0, totalImages - 1);
      }
      else {
      imageNum = (imageNum 1) % totalImages;
      }
      var new_image = get_ImageItemLocation(imageArray[imageNum]);
      return new_image;
      }

      function getPrevImage() {
      imageNum = (imageNum - 1) % totalImages;
      var new_image = get_ImageItemLocation(imageArray[imageNum]);
      return new_image;
      }

      function prevImage(place) {
      var new_image = getPrevImage();
      document[place].src = new_image;
      }

      function switchImage(place) {
      var new_image = getNextImage();
      document[place].src = new_image;
      timerID = setTimeout (function() {switchImage(place); }, interval);

      }





      play slide show
      pause
      previous
      next




      Ron "hedgehog" Jeremy

      • Avusta kiittäen...

        kokeilin tuota scriptiä korjattuna versiona ja toimii nyt paljon paremmin kuin tuo aiempi versio. Antaa kuitenkin vielä seuraavan virheilmoituksen...muutaman kuvanpalautuksen jälkeen...

        Rivi: 25
        Merkki: 1
        "image_item" on 0 tai ei ole objekti
        Koodi: 0

        Virheellinen rivikoodi:

        return imageObj.image_item.src;

        .................................................

        * Löytyisikö vielä varmistusta asiaan, mitä pitäisi tehdä ? Kiitos...


    • Ron Jeremy

      Hiukan toi skripti tarvitsi vielä viilaamista, sinulla puuttui m.m kokonaan nextImage() funktio, muutin myös switchImage() funktiota jotta voit käyttää getNextImage() funktiota sellaisenaan next linkissä...myös pieniä muutoksia siellä täällä (kaikki muutokset eivät olleet välttämättömiä):



      Javascript slide show testi


      var interval = 1500;
      var random_display = false;
      var imageDir = "";
      var imageNum = 0;

      var imageArray = new Array();
      imageArray[imageArray.length] = new imageItem(imageDir "Etusivu.jpg");
      imageArray[imageArray.length] = new imageItem(imageDir "Etusivu.gif");
      imageArray[imageArray.length] = new imageItem(imageDir "Etusivu.png");
      imageArray[imageArray.length] = new imageItem(imageDir "Etusivu.jpg");
      imageArray[imageArray.length] = new imageItem(imageDir "Etusivu.png");

      var totalImages = imageArray.length;

      function imageItem(image_location) {
      this.image_item = new Image();
      this.image_item.src = image_location;
      }

      function get_ImageItemLocation(imageObj) {
      return imageObj.image_item.src;
      }

      function randNum(x, y) {
      var range = y - x 1;
      return Math.floor(Math.random() * range) x;
      }

      function getNextImage() {
      imageNum = (imageNum 1) % totalImages;
      var new_image = get_ImageItemLocation(imageArray[imageNum]);
      return new_image;
      }

      function getPrevImage() {
      if (imageNum == 0) {
      imageNum = totalImages - 1;
      }
      else {
      imageNum = (imageNum - 1) % totalImages;
      }
      var new_image = get_ImageItemLocation(imageArray[imageNum]);
      return new_image;
      }

      function prevImage(place) {
      var new_image = getPrevImage();
      document[place].src = new_image;
      }

      function nextImage(place) {
      var new_image = getNextImage();
      document[place].src = new_image;
      }


      function switchImage(place) {
      if (random_display) {
      var currentNum = imageNum;
      while (currentNum == imageNum)
      imageNum = randNum (0, totalImages - 1);
      }
      else {
      imageNum = (imageNum 1) % totalImages;
      }
      document[place].src = get_ImageItemLocation(imageArray[imageNum]);
      timerID = setTimeout (function() {switchImage(place); }, interval);

      }







      play slide show
      pause
      previous
      next




      Ron "hedgehog" Jeremy

      • Ron Jeremy

        Selvyyden vuoksi määrittele timerID muuttuja globaaliksi muutujaksi eksplisiittisesti ennen skriptin käynnistymistä:

        var interval = 1500;
        var random_display = false;
        var imageDir = "";
        var imageNum = 0;
        var timerID = null;

        Huomaa myös että prev&next linkit eivät näytä aidosti edellistä&seuraavaa kuvaa jos näytät kuvia satunnaisesti (var random_display = true)..tämä vaatisi sen että lisäisit jokaisen satunnaisesti näytetyn kuvanumeron erilliseen taulukkoon ja käsittelisit tätä taulukkoa getPrevImage() ja getNextImage() funktiossa silloin kun random_display muuttuja on tosi.

        Ron "hedgehog" Jeremy


      • Ron Jeremy
        Ron Jeremy kirjoitti:

        Selvyyden vuoksi määrittele timerID muuttuja globaaliksi muutujaksi eksplisiittisesti ennen skriptin käynnistymistä:

        var interval = 1500;
        var random_display = false;
        var imageDir = "";
        var imageNum = 0;
        var timerID = null;

        Huomaa myös että prev&next linkit eivät näytä aidosti edellistä&seuraavaa kuvaa jos näytät kuvia satunnaisesti (var random_display = true)..tämä vaatisi sen että lisäisit jokaisen satunnaisesti näytetyn kuvanumeron erilliseen taulukkoon ja käsittelisit tätä taulukkoa getPrevImage() ja getNextImage() funktiossa silloin kun random_display muuttuja on tosi.

        Ron "hedgehog" Jeremy

        ..että sinun pitää myös estää se mahdollisuus että skriptin käyttäjä painaa "play slide show" linkkiä silloin kun slideshow on jo käynnissä esim. määritelemällä sopivasti muuttuja joka ilmaisee onko slideshow käynnissä vai ei.

        Ron "hedgehog" Jeremy


      • ...
        Ron Jeremy kirjoitti:

        ..että sinun pitää myös estää se mahdollisuus että skriptin käyttäjä painaa "play slide show" linkkiä silloin kun slideshow on jo käynnissä esim. määritelemällä sopivasti muuttuja joka ilmaisee onko slideshow käynnissä vai ei.

        Ron "hedgehog" Jeremy

        Hienoa työtä.

        Nyt näyttäisi toimivan...ja opinkin taas paljon uutta näistä kommenteista.


    Ketjusta on poistettu 0 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
      54
      9938
    2. Voiko normaali ihminen ryhtyä vasemmistolaiseksi?

      Tätä jäin pohdiskelemaan.
      Maailman menoa
      225
      4446
    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
      155
      3882
    4. Orpo: Velkajarrua vastustavaa puoluetta vaikea ajatella hallitukseen

      No Minja Koskelan kommunistipuolue jäi ulos tuosta. Kaikki eduskuntapuolueet vasemmistoliittoa lukuun ottamatta sopivat
      Maailman menoa
      146
      3344
    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
      37
      3119
    6. Mikä tämä henkilö mahtaa touhuta Parkanossa

      Kamalaa https://www.ylasatakunta.fi/teksti/pirkanmaan-karajaoikeus-vangitsi-koiran-tappamisesta-epaillyn-6.68.127794.b58
      Parkano
      30
      2183
    7. 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ä
      20
      1840
    8. 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
      62
      1706
    9. Sulla on avaimet ja keinot

      Jos haluat jatkaa tutustumista. Itse olen niin jäässä etten pysty tekemään enää mitään. Pidempi keppi johon on helpompi
      Ikävä
      25
      1435
    10. Orpo loukkaantui fasismiin viittaavasta sanavalinnasta

      Mutta miksi loukkaantui? Orpohan on tehnyt yhteistyötä fasistien kanssa jo vuonna 2019, siis jo neljä vuotta ennen loukk
      Maailman menoa
      32
      1389
    Aihe