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="mindraper" data-source="post: 1921635" data-attributes="member: 115163"><p><strong>AW: Javascript: Array Werte tauschen</strong></p><p></p><p>hi.</p><p></p><p></p><p></p><p>simple solution: dreh die schleife um. </p><p></p><p>[PHP]</p><p>var pos;</p><p>for( pos = feldAnzahl -1; pos > 0; pos-- ){</p><p> /* CODE */</p><p>}</p><p>[/PHP]</p><p></p><p>damit wird das array statt von position 0 beginnend von der letzten position an durchlaufen. sofern "feldAnzahl" so groß ist wie die anzahl der inhalte im array - 1 ( also array.length -1 ).</p><p></p><p>was ich mit logik-fehler meinte ist folgendes:</p><p>ich sehe ja nicht mehr von deinem code als du hier zeigst, deshalb kann ich mich nur darauf stützen. daher</p><p></p><p>1. dein array "bilder" ist leer, hat also keine inhalte.</p><p></p><p>2. innerhalb von "verschieben" wird "bilder" 2 mal durchlaufen, am ende rufst du "austauschen" auf.</p><p></p><p>3. bei jedem aufruf von "austauschen", wird "bilder" ein zusätzliches 'blank' hinzugefügt durch bilder.push( 'blank' ). d. h., nach dem ersten aufruf von "austauschen" ist 'blank' einmal in bilder drinne, beim zweiten aufruf 2mal, dann 3mal usw.</p><p></p><p>4. das führt dann also beim zweiten aufruf von "verschieben" dazu, dass die function nicht mehr korrekt arbeitet. denn sie findet den wert 'blank' ja 2mal im array. ich kann mir eigentlich nicht vorstellen, dass du "verschieben" nur ein einziges mal aufrufen willst. oder täusche ich mich in dieser hinsicht?</p><p></p><p>da es ja jetzt doch schon spät ist, habe ich dir hier mal was kleines zusammengebastelt, das z. zt. noch etwas buggy ist. ansonsten sollte es aber soweit erstmal funktionieren. feilen musst du dann schon selbst <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" class="smilie smilie--sprite smilie--sprite1" alt=":)" title="Smile :)" loading="lazy" data-shortname=":)" /></p><p></p><p>[PHP]</p><p>var counter, maxCount, elems, indexOf, bilder = [], imgTags = [], zeile = 3, spalte = 2; </p><p></p><p>indexOf = Array.prototype.indexOf || function( thing ){</p><p> var i;</p><p> for( i = 0; i < this.length; i += 1 ){</p><p> if( this[i] === thing ){</p><p> return i;</p><p> }</p><p> }</p><p> return -1;</p><p>}</p><p></p><p>for( counter = 0, maxCount = zeile * spalte; counter < maxCount; counter += 1 ){</p><p> var content, elem, src = counter + '.jpg';</p><p> </p><p> elem = document.getElementById( 'bild_' + counter );</p><p> elem.src = src;</p><p> </p><p> bilder.push( src );</p><p>}</p><p></p><p>bilder.push( 'blank.jpg' );</p><p>document.getElementById( 'bild_5' ).src = 'blank.jpg';</p><p></p><p>function change(){</p><p> var i;</p><p> for( i = 0; i < bilder.length; i += 1 ){</p><p> document.getElementById( 'bild_' + i ).src = bilder[i];</p><p> }</p><p>}</p><p></p><p>function shuffle( array, id ){</p><p> var temp, i = array.indexOf( 'blank.jpg' ),</p><p> j = array.indexOf( id );</p><p> </p><p> temp = array[i];</p><p> array[i] = array[j];</p><p> array[j] = temp;</p><p> setTimeout( change, 15 );</p><p>}</p><p></p><p>document.getElementById( 'bild_0' ).onclick = function(){</p><p> shuffle( bilder, '0.jpg' );</p><p>}</p><p>document.getElementById( 'bild_1' ).onclick = function(){</p><p> shuffle( bilder, '1.jpg' );</p><p>}</p><p>document.getElementById( 'bild_2' ).onclick = function(){</p><p> shuffle( bilder, '2.jpg' );</p><p>}</p><p>document.getElementById( 'bild_3' ).onclick = function(){</p><p> shuffle( bilder, '3.jpg' );</p><p>}</p><p>document.getElementById( 'bild_4' ).onclick = function(){</p><p> shuffle( bilder, '4.jpg' );</p><p>}</p><p>document.getElementById( 'bild_5' ).onclick = function(){</p><p> shuffle( bilder, '5.jpg' );</p><p>}</p><p>[/PHP]</p><p></p><p>HTML seitig sieht es so aus:</p><p></p><p>[HTML]</p><p><img src="" alt="bild_0" id="bild_0"></p><p><img src="" alt="bild_1" id="bild_1"></p><p><img src="" alt="bild_2" id="bild_2"></p><p><img src="" alt="bild_3" id="bild_3"></p><p><img src="" alt="bild_4" id="bild_4"></p><p><img src="" alt="bild_5" id="bild_5"></p><p>[/HTML]</p><p></p><p>hoffe das hilft</p></blockquote><p></p>
[QUOTE="mindraper, post: 1921635, member: 115163"] [b]AW: Javascript: Array Werte tauschen[/b] hi. simple solution: dreh die schleife um. [PHP] var pos; for( pos = feldAnzahl -1; pos > 0; pos-- ){ /* CODE */ } [/PHP] damit wird das array statt von position 0 beginnend von der letzten position an durchlaufen. sofern "feldAnzahl" so groß ist wie die anzahl der inhalte im array - 1 ( also array.length -1 ). was ich mit logik-fehler meinte ist folgendes: ich sehe ja nicht mehr von deinem code als du hier zeigst, deshalb kann ich mich nur darauf stützen. daher 1. dein array "bilder" ist leer, hat also keine inhalte. 2. innerhalb von "verschieben" wird "bilder" 2 mal durchlaufen, am ende rufst du "austauschen" auf. 3. bei jedem aufruf von "austauschen", wird "bilder" ein zusätzliches 'blank' hinzugefügt durch bilder.push( 'blank' ). d. h., nach dem ersten aufruf von "austauschen" ist 'blank' einmal in bilder drinne, beim zweiten aufruf 2mal, dann 3mal usw. 4. das führt dann also beim zweiten aufruf von "verschieben" dazu, dass die function nicht mehr korrekt arbeitet. denn sie findet den wert 'blank' ja 2mal im array. ich kann mir eigentlich nicht vorstellen, dass du "verschieben" nur ein einziges mal aufrufen willst. oder täusche ich mich in dieser hinsicht? da es ja jetzt doch schon spät ist, habe ich dir hier mal was kleines zusammengebastelt, das z. zt. noch etwas buggy ist. ansonsten sollte es aber soweit erstmal funktionieren. feilen musst du dann schon selbst :) [PHP] var counter, maxCount, elems, indexOf, bilder = [], imgTags = [], zeile = 3, spalte = 2; indexOf = Array.prototype.indexOf || function( thing ){ var i; for( i = 0; i < this.length; i += 1 ){ if( this[i] === thing ){ return i; } } return -1; } for( counter = 0, maxCount = zeile * spalte; counter < maxCount; counter += 1 ){ var content, elem, src = counter + '.jpg'; elem = document.getElementById( 'bild_' + counter ); elem.src = src; bilder.push( src ); } bilder.push( 'blank.jpg' ); document.getElementById( 'bild_5' ).src = 'blank.jpg'; function change(){ var i; for( i = 0; i < bilder.length; i += 1 ){ document.getElementById( 'bild_' + i ).src = bilder[i]; } } function shuffle( array, id ){ var temp, i = array.indexOf( 'blank.jpg' ), j = array.indexOf( id ); temp = array[i]; array[i] = array[j]; array[j] = temp; setTimeout( change, 15 ); } document.getElementById( 'bild_0' ).onclick = function(){ shuffle( bilder, '0.jpg' ); } document.getElementById( 'bild_1' ).onclick = function(){ shuffle( bilder, '1.jpg' ); } document.getElementById( 'bild_2' ).onclick = function(){ shuffle( bilder, '2.jpg' ); } document.getElementById( 'bild_3' ).onclick = function(){ shuffle( bilder, '3.jpg' ); } document.getElementById( 'bild_4' ).onclick = function(){ shuffle( bilder, '4.jpg' ); } document.getElementById( 'bild_5' ).onclick = function(){ shuffle( bilder, '5.jpg' ); } [/PHP] HTML seitig sieht es so aus: [HTML] <img src="" alt="bild_0" id="bild_0"> <img src="" alt="bild_1" id="bild_1"> <img src="" alt="bild_2" id="bild_2"> <img src="" alt="bild_3" id="bild_3"> <img src="" alt="bild_4" id="bild_4"> <img src="" alt="bild_5" id="bild_5"> [/HTML] hoffe das hilft [/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