PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Javascript: Array Werte tauschen
Beitrag
<blockquote data-quote="Greenhorn79" data-source="post: 1924751" data-attributes="member: 346865"><p><strong>AW: Javascript: Array Werte tauschen</strong></p><p></p><p>Habe doch noch ein größeres Problem:</p><p></p><p>Am Anfang möchte ich innerhalb einer Schleife in der Funktion mischen sehr oft die Verschiebefunktion aufrufen. Leider funktioniert das aber nicht. Das Problem liegt an break in der Schleife innerhalb der Verschiebefunktion. Nehme ich hier ein return, dann klappt das verschieben nicht mehr aber die Funktion wird dafür entsprechend der Schleife innerhalb der Funktion mischen aufgerufen. Ich poste mal meinen gesamten Code....</p><p></p><p>[CODE]</p><p>var bilder = [];</p><p></p><p></p><p>function verschieben(id) {</p><p> for(var bildNr = 0; bildNr < bilder.length; ++bildNr) {</p><p> if(bilder[bildNr] == 'blank') {</p><p> //Bildnummer der Lücke</p><p> i = bildNr;</p><p> alert('Luecke ' + i);</p><p> break;</p><p> }</p><p> }</p><p> var trennPos = id.indexOf("_");</p><p> var nr = id.substring(trennPos + 1);</p><p> alert('teil' + nr);</p><p> for(var bildNr = 0; bildNr < bilder.length; ++bildNr) {</p><p> j = nr;</p><p> }</p><p> var status = pruefen(i,j);</p><p> if(status== false) {</p><p> return;</p><p> }</p><p> var temp = bilder[i];</p><p> bilder[i] = bilder[j];</p><p> bilder[j] = temp;</p><p> alert(bilder);</p><p> austauschen()</p><p>}</p><p></p><p>function fuellenArray() {</p><p> var feldAnzahl = spalte*zeile;</p><p> for(i= 0; i < feldAnzahl-1; ++i) {</p><p> bilder.push(i);</p><p> }</p><p>bilder[feldAnzahl-1] = ('blank');</p><p>}</p><p></p><p>function pruefen(i,j) {</p><p> if(i-j == 1 || j-i == 1) {</p><p> return true;</p><p> } else {</p><p> if(i-j == spalte || j-i == spalte) {</p><p> return true;</p><p> } else {</p><p> return false;</p><p> }</p><p> }</p><p></p><p>}</p><p></p><p>function austauschen() {</p><p> var feldAnzahl = spalte*zeile;</p><p></p><p> for(var bildNr = 0; bildNr < feldAnzahl; ++bildNr) {</p><p> var bild = document.getElementById('bilder_' + bildNr);</p><p> bild.src = bilder[bildNr] + '.jpg';</p><p> }</p><p>}</p><p></p><p>function mischen() {</p><p> for (i = 0; i <100; ++i) {</p><p> var id = Math.floor(Math.random() * (spalte*zeile + 1));</p><p> alert(id);</p><p> verschieben(id);</p><p> }</p><p>}</p><p></p><p>function generieren() {</p><p> bilder = [];</p><p> var groesse = document.getElementById('groesse').value;</p><p> spalte = parseInt(groesse.substr(0,1));</p><p> zeile = parseInt(groesse.substr(2,1));</p><p> document.getElementById("puzzle").innerHTML = '';</p><p> //Erzeugen der Zeilen</p><p> for (var k =0; k<zeile; ++k) {</p><p> document.getElementById("puzzle").innerHTML = document.getElementById("puzzle").innerHTML + '<div id="zeile' + k + '"></div>';</p><p> }</p><p> //Erzeugen der Zeilen</p><p> for (var i = 0; i<spalte; ++i) {</p><p> document.getElementById("zeile0").innerHTML = document.getElementById("zeile0").innerHTML + '<img id="bilder_' + i + '" src="blank.jpg " onclick = "verschieben(id)";/>';</p><p> document.getElementById("zeile1").innerHTML = document.getElementById("zeile1").innerHTML + '<img id="bilder_' + (i+spalte) + '" src="blank.jpg" onclick = "verschieben(id)";/>';</p><p> document.getElementById("zeile2").innerHTML = document.getElementById("zeile2").innerHTML + '<img id="bilder_' + (i+2*spalte) + '" src="blank.jpg" onclick = "verschieben(id)";/>';</p><p> }</p><p> if(zeile == 4) {</p><p> for (var i = 0; i<spalte; ++i) {</p><p> document.getElementById("zeile3").innerHTML = document.getElementById("zeile3").innerHTML + '<img id="bilder_' + (i+3*spalte) + '" src="blank.jpg" onclick = "verschieben(id)";/>';</p><p> }</p><p> }</p><p>fuellenArray();</p><p>austauschen();</p><p>mischen();</p><p> }</p><p>[/CODE]</p></blockquote><p></p>
[QUOTE="Greenhorn79, post: 1924751, member: 346865"] [b]AW: Javascript: Array Werte tauschen[/b] Habe doch noch ein größeres Problem: Am Anfang möchte ich innerhalb einer Schleife in der Funktion mischen sehr oft die Verschiebefunktion aufrufen. Leider funktioniert das aber nicht. Das Problem liegt an break in der Schleife innerhalb der Verschiebefunktion. Nehme ich hier ein return, dann klappt das verschieben nicht mehr aber die Funktion wird dafür entsprechend der Schleife innerhalb der Funktion mischen aufgerufen. Ich poste mal meinen gesamten Code.... [CODE] var bilder = []; function verschieben(id) { for(var bildNr = 0; bildNr < bilder.length; ++bildNr) { if(bilder[bildNr] == 'blank') { //Bildnummer der Lücke i = bildNr; alert('Luecke ' + i); break; } } var trennPos = id.indexOf("_"); var nr = id.substring(trennPos + 1); alert('teil' + nr); for(var bildNr = 0; bildNr < bilder.length; ++bildNr) { j = nr; } var status = pruefen(i,j); if(status== false) { return; } var temp = bilder[i]; bilder[i] = bilder[j]; bilder[j] = temp; alert(bilder); austauschen() } function fuellenArray() { var feldAnzahl = spalte*zeile; for(i= 0; i < feldAnzahl-1; ++i) { bilder.push(i); } bilder[feldAnzahl-1] = ('blank'); } function pruefen(i,j) { if(i-j == 1 || j-i == 1) { return true; } else { if(i-j == spalte || j-i == spalte) { return true; } else { return false; } } } function austauschen() { var feldAnzahl = spalte*zeile; for(var bildNr = 0; bildNr < feldAnzahl; ++bildNr) { var bild = document.getElementById('bilder_' + bildNr); bild.src = bilder[bildNr] + '.jpg'; } } function mischen() { for (i = 0; i <100; ++i) { var id = Math.floor(Math.random() * (spalte*zeile + 1)); alert(id); verschieben(id); } } function generieren() { bilder = []; var groesse = document.getElementById('groesse').value; spalte = parseInt(groesse.substr(0,1)); zeile = parseInt(groesse.substr(2,1)); document.getElementById("puzzle").innerHTML = ''; //Erzeugen der Zeilen for (var k =0; k<zeile; ++k) { document.getElementById("puzzle").innerHTML = document.getElementById("puzzle").innerHTML + '<div id="zeile' + k + '"></div>'; } //Erzeugen der Zeilen for (var i = 0; i<spalte; ++i) { document.getElementById("zeile0").innerHTML = document.getElementById("zeile0").innerHTML + '<img id="bilder_' + i + '" src="blank.jpg " onclick = "verschieben(id)";/>'; document.getElementById("zeile1").innerHTML = document.getElementById("zeile1").innerHTML + '<img id="bilder_' + (i+spalte) + '" src="blank.jpg" onclick = "verschieben(id)";/>'; document.getElementById("zeile2").innerHTML = document.getElementById("zeile2").innerHTML + '<img id="bilder_' + (i+2*spalte) + '" src="blank.jpg" onclick = "verschieben(id)";/>'; } if(zeile == 4) { for (var i = 0; i<spalte; ++i) { document.getElementById("zeile3").innerHTML = document.getElementById("zeile3").innerHTML + '<img id="bilder_' + (i+3*spalte) + '" src="blank.jpg" onclick = "verschieben(id)";/>'; } } fuellenArray(); austauschen(); mischen(); } [/CODE] [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 7, ▼ = 3, ◇ = 2 und die Summe von ▲ und ▼ durch ◇ geteilt wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Javascript: Array Werte tauschen
Oben