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
Miksi tämä scripti ei toimi?
6
3869
Vastaukset
- 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" JeremyHienoa 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
Eläkeläiset siirrettävä muuttotappioalueille
Joutoväki pois ruuhkauttamasta elättäjien arkea. Samalla putoaa jokaisen asumiskulut ja rahaa jää enemmän kuluttamiseen.4493316SDP pelastaa uppoavan Suomen
2027 kun SDP voittaa ylivoimaisesti vaalit alkaa Suomen uusi raju syöksy kohti täystyöllisyyttä ja turvallisempaa yhteis1012541Kauppalehti - Törkeä skandaali paljastui: Espanja käytti EU-rahoja ihan muuhun kuin piti
Espanja on käyttänyt miljardeja euroja EU:n elpymisavustuksia eläkkeisiin ja sosiaalimenoihin – ja pyytää lisää. Espanj842102Jopa Espanjassa talous kasvaa, Purra vain irvistelee
Huomaa kuinka Purra on Suomen historian huonoin miniseteri, joka ei ole saanut aikaiseksi kuin tuhoa, Siis jopa vasemmis1401876- 1441717
- 851456
Jääkiekon MM:t pitää siirtää MTV:ltä Ylelle
Persuille ikäviä uutisia taas. . Valtioneuvoston asetuksen mukaan MM-kisat kuuluvat kansallisesti merkittäviin tapahtumi261432Raiskaukset loppumaan?
Onko kenelläkään tiedossaan tuloksellisia keinoja saada väkisinmakaaminen loppumaan tai edes vähenemään? Lainsäädännön3171235Tsemii Pete ja Linda! Tässä tärkeät kellonajat Euroviisut-viikon ohjelmista tv:ssä!
Euroviisut järjestetään Wienissä Itävallassa 12.-16. toukokuuta. Tsemii Pete ja Linda kisaan! Vetäkää Suomelle voitto Li211201Uuden upotuskasteen vaiettu ongelma
Alkuseurakunnan kaste oli useamman vuosisadan upotuskaste, joka toimitettiin joko ulkona luonnon vesistöissä tai kasteki1021069