Voortgangsindicator VIII: Snake in een popup

JavaScript is niet bedoeld om grote, ingewikkelde berekeningen uit te voeren. Als je het toch probeert zul je vaak lang moeten wachten op het resultaat. Ook kan je PC erg traag worden.
In dergelijke gevallen is het handig als je op het scherm kunt zien dat er voortgang wordt geboekt bij de berekeningen en dat de PC of de browser -dus- niet hangt of zo. Het voorkomt ook dat de browser een melding geeft dat een script niet reageert omdat er geen interactie met het scherm is.

Voorbeeld:
Op deze website, in de rubriek "Rekenen", vind je een beschrijving van een priemgetallen zeef. Die is redelijk snel, zolang je er niet te veel van vraagt. Maar als je bijvoorbeeld 6000 priemgetallen wilt laten berekenen, is je PC even bezig...
Voor de rekenaars onder ons: het 6000e priemgetal is 53 359.

Voor langdurige processen waarvan niet te bepalen is hoe lang het gaat duren is een snake heel geschikt. Een snake is een rijtje karakters of figuurtjes dat in een horizontale balk beweegt. De beweging geeft aan dat het proces vordert.
Een goed voorbeeld van een toepassing is de balk met de bewegende blokjes in het startscherm van Windows XP en Vista.

Op deze bladzijde wordt een snake voorgesteld die werkt in een popup. Elders op deze site, in de rubriek Rekenen, vind je uitvoeringen die in de tekst of in een formulier-veld verschijnen.

Als je op de knop Start Voorbeeld klikt wordt er een script gestart dat een lange berekening simuleert.
Er verschijnt een popup met daarin een figuur waarin de voortgang van de simulatie wordt getoond. Dit is de snake. Als de beweging stopt, is de berekening klaar.
Als je vervolgens op Stop Voorbeeld klikt, stopt de simulatie. Na een klik op Einde verdwijnt de popup.

De code van de popup met de snake kun je downloaden om zelf te gebruiken.

Opmerking:
 
Hoewel deze code op zich vrij eenvoudig is, raad ik het beginnende programmeurs af om dit te gebruiken. De toepassing er van is namelijk vrij lastig. Feitelijk is het pure overhead; de voortgang van het rekenproces wordt steeds even onderbroken om het scherm bij te werken. Je moet daarom heel goed weten waar en wannéér je het rekenproces moet / kunt onderbreken.
Gebruik het dus alleen als je er echt een zinvolle toepassing voor hebt.

De code ziet er als volgt uit:
 
(Zet dit in de <HEAD>).

<script src="pisnake3.js"></script>

(Zet dit in de <BODY>, op de plaats waar dat nodig is).

<script>
  Init_Popup_Snake();
</script>

(Voeg code toe in de <HEAD> en/of de <BODY> waar je hem nodig hebt, zoals hierboven is beschreven).

Downloaden:
 
Druk op de knop: Download deze code  File: voorb201.zip, 3743 bytes.

Opmerking:
 
Nogmaals: gebruik dit alleen als je weet wat je doet! Cool!
 
Elders op deze site staan vergelijkbare snake-bars, die echter worden getoond in een formulierveld of in de tekst.
 
Een 'mooiere' versie van het script om popups te maken vind je in het item Lokale Popup in een DIV-tag II: mouseclick.

 
terug

html-201; Laatste wijziging: 30 juni 2022