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...
JQuery findet Dynamisch erzeugte IDs nicht
Beitrag
<blockquote data-quote="Daniel_Knecht" data-source="post: 2714264" data-attributes="member: 7535"><p>Hallöchen,</p><p>ich melde mich mal wieder mit einem Problem"chen" welches mich schon seit einigen tagen "Ausbremst".</p><p>Und zwar erstelle ich mit JQuery Dynamich mehrere Input felder (welche ich via CSS geändert habe. Das ist soweit alles kein Problem und Funktioniert auch.</p><p></p><p>Nun ist mein Problem jedoch das ich den Dateinamen der Datei die ich auswähle ab dem 2. Input nicht mehr angezeigt bekomme.</p><p>An den IDs welche ich mit JQuery (Variable i) erzeuge liegt es nicht. Ich bin mittlerweile auch ratlos was ich noch machen könnte um dies zum laufen zu bekommen.</p><p></p><p>Wie gesagt das erste Input funktioniert (Ist auch Fest im HTML Code eingetragen. Ab dem 2. Input welche Dynamisch ereugt werden klappt es nicht. Die Dateien sind ausgewählt werden aber wie gesagt nicht angezeigt.</p><p></p><p>HTML/PHP</p><p>[PHP]<div id="fileUpload_field"></p><p> <div class="fileUpload_button">BROWSE...</p><p> <input type="file" id="1" class="upload" name="uploadPreviews[]" /></p><p> </div></p><p> <input id="uploadPreview_1" class="fileUpload_text" value="Nothing selected..." readonly /></p><p> <a href="javascript:void(0);" class="fileUpload_add"><i class="fas fa-plus"></i></a></p><p> </div>[/PHP]</p><p></p><p>JQUERY</p><p>[CODE]$(document).ready(function(){</p><p> var maxField = 6; //Input fields increment limitation</p><p> var wrapper = $('.upload_wrapper'); //Input field wrapper</p><p> var addButton = $('.fileUpload_add'); //Add button selector</p><p> //var fieldHTML = '<div id="fileUpload_field"><div class="fileUpload_button">BROWSE...<input type="file" class="upload" name="uploadPreviews[]" /></div><input id="uploadPreviews" class="fileUpload_text" value="Nothing selected..." readonly /><a href="javascript:void(0);" class="fileUpload_del"><i class="fas fa-minus"></i></a></div>'; //New input field html</p><p> var x = 1; //Initial field counter is 1</p><p> var i = 1;</p><p> </p><p> //Once add button is clicked</p><p> $(addButton).click(function(){</p><p> //Check maximum number of input fields</p><p> if(x < maxField){</p><p> x++; //Increment field counter</p><p> i++;</p><p> $(wrapper).append('<div id="fileUpload_field" style="margin-top:5px"><div class="fileUpload_button">BROWSE...<input type="file" id="'+i+'" class="upload" name="uploadPreviews[]" /></div><input id="uploadPreview_'+i+'" class="fileUpload_text" value="Nothing selected..." readonly /><a href="javascript:void(0);" class="fileUpload_del"><i class="fas fa-minus"></i></a></div>'); //Add field html</p><p> }</p><p> });</p><p> </p><p> //Once remove button is clicked</p><p> $(wrapper).on('click', '.fileUpload_del', function(e){</p><p> e.preventDefault();</p><p> $(this).parent('div').remove(); //Remove field html</p><p> x--; //Decrement field counter</p><p> });</p><p> </p><p> $('input[type=file][name="uploadPreviews[]"]').change(function(e){</p><p> if (e.target.id == 1) {</p><p> alert('id: '+e.target.id);</p><p> $("#uploadPreview_1").attr('value', this.value.replace(/C:\\fakepath\\/, ''));</p><p> }</p><p> if (e.target.id == 2) {</p><p> alert('id: '+e.target.id);</p><p> $("#uploadPreview_2").attr('value', this.value.replace(/C:\\fakepath\\/, ''));</p><p> }</p><p> if (e.target.id == 3) {</p><p> alert('id: '+e.target.id);</p><p> $("#uploadPreview_3").attr('value', this.value.replace(/C:\\fakepath\\/, ''));</p><p> }</p><p> if (e.target.id == 4) {</p><p> alert('id: '+e.target.id);</p><p> $("#uploadPreview_4").attr('value', this.value.replace(/C:\\fakepath\\/, ''));</p><p> }</p><p> if (e.target.id == 5) {</p><p> alert('id: '+e.target.id);</p><p> $("#uploadPreview_5").attr('value', this.value.replace(/C:\\fakepath\\/, ''));</p><p> }</p><p> if (e.target.id == 6) {</p><p> alert('id: '+e.target.id);</p><p> $("#uploadPreview_6").attr('value', this.value.replace(/C:\\fakepath\\/, ''));</p><p> }</p><p> });</p><p>});[/CODE]</p><p></p><p>Ich hoffe ihr könnt mir weiterhelfen.</p></blockquote><p></p>
[QUOTE="Daniel_Knecht, post: 2714264, member: 7535"] Hallöchen, ich melde mich mal wieder mit einem Problem"chen" welches mich schon seit einigen tagen "Ausbremst". Und zwar erstelle ich mit JQuery Dynamich mehrere Input felder (welche ich via CSS geändert habe. Das ist soweit alles kein Problem und Funktioniert auch. Nun ist mein Problem jedoch das ich den Dateinamen der Datei die ich auswähle ab dem 2. Input nicht mehr angezeigt bekomme. An den IDs welche ich mit JQuery (Variable i) erzeuge liegt es nicht. Ich bin mittlerweile auch ratlos was ich noch machen könnte um dies zum laufen zu bekommen. Wie gesagt das erste Input funktioniert (Ist auch Fest im HTML Code eingetragen. Ab dem 2. Input welche Dynamisch ereugt werden klappt es nicht. Die Dateien sind ausgewählt werden aber wie gesagt nicht angezeigt. HTML/PHP [PHP]<div id="fileUpload_field"> <div class="fileUpload_button">BROWSE... <input type="file" id="1" class="upload" name="uploadPreviews[]" /> </div> <input id="uploadPreview_1" class="fileUpload_text" value="Nothing selected..." readonly /> <a href="javascript:void(0);" class="fileUpload_add"><i class="fas fa-plus"></i></a> </div>[/PHP] JQUERY [CODE]$(document).ready(function(){ var maxField = 6; //Input fields increment limitation var wrapper = $('.upload_wrapper'); //Input field wrapper var addButton = $('.fileUpload_add'); //Add button selector //var fieldHTML = '<div id="fileUpload_field"><div class="fileUpload_button">BROWSE...<input type="file" class="upload" name="uploadPreviews[]" /></div><input id="uploadPreviews" class="fileUpload_text" value="Nothing selected..." readonly /><a href="javascript:void(0);" class="fileUpload_del"><i class="fas fa-minus"></i></a></div>'; //New input field html var x = 1; //Initial field counter is 1 var i = 1; //Once add button is clicked $(addButton).click(function(){ //Check maximum number of input fields if(x < maxField){ x++; //Increment field counter i++; $(wrapper).append('<div id="fileUpload_field" style="margin-top:5px"><div class="fileUpload_button">BROWSE...<input type="file" id="'+i+'" class="upload" name="uploadPreviews[]" /></div><input id="uploadPreview_'+i+'" class="fileUpload_text" value="Nothing selected..." readonly /><a href="javascript:void(0);" class="fileUpload_del"><i class="fas fa-minus"></i></a></div>'); //Add field html } }); //Once remove button is clicked $(wrapper).on('click', '.fileUpload_del', function(e){ e.preventDefault(); $(this).parent('div').remove(); //Remove field html x--; //Decrement field counter }); $('input[type=file][name="uploadPreviews[]"]').change(function(e){ if (e.target.id == 1) { alert('id: '+e.target.id); $("#uploadPreview_1").attr('value', this.value.replace(/C:\\fakepath\\/, '')); } if (e.target.id == 2) { alert('id: '+e.target.id); $("#uploadPreview_2").attr('value', this.value.replace(/C:\\fakepath\\/, '')); } if (e.target.id == 3) { alert('id: '+e.target.id); $("#uploadPreview_3").attr('value', this.value.replace(/C:\\fakepath\\/, '')); } if (e.target.id == 4) { alert('id: '+e.target.id); $("#uploadPreview_4").attr('value', this.value.replace(/C:\\fakepath\\/, '')); } if (e.target.id == 5) { alert('id: '+e.target.id); $("#uploadPreview_5").attr('value', this.value.replace(/C:\\fakepath\\/, '')); } if (e.target.id == 6) { alert('id: '+e.target.id); $("#uploadPreview_6").attr('value', this.value.replace(/C:\\fakepath\\/, '')); } }); });[/CODE] Ich hoffe ihr könnt mir weiterhelfen. [/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...
JQuery findet Dynamisch erzeugte IDs nicht
Oben