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...
JavaSript - cloneNode und Werte ändern
Beitrag
<blockquote data-quote="mindraper" data-source="post: 2387797" data-attributes="member: 115163"><p>moinsen,</p><p></p><p>tablerow elemente kennen das value-attribut nicht. aus diesem grund funktioniert "setAttribute" hier nicht. es gibt hier mehrere lösungen, im folgenden beschrieben von "sauberste" zu "unsauberste":</p><ol> <li data-xf-list-type="ol">eines der globalen html-attribute verwenden. beispielsweise "title", "class", "data-xxx" oder sonstige der verfügbaren. eine übersicht gibt's hier:<br /> <a href="https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes" target="_blank">https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes</a></li> <li data-xf-list-type="ol">bereits geklonte tr-elemente als referenzvariablen in einem array oder object cachen und vor dem erzeugen eines neuen klons abgleichen, ob schon eine kopie erzeugt wurde. in javascript werden dom-elemente by-reference verglichen, nicht by-value, so dass ein bereits erzeugter klon faktisch immer eindeutig ist und per striktem vergleich (===) abgeglichen werden kann.<br /> [CODE]// contains every tr which has already been cloned<br /> var cloned = [];<br /> <br /> var isAlreadyCloned = function (node) {<br /> // iterator function to check if the given<br /> // node has already been cloned<br /> return function (cloned) {<br /> return cloned === node;<br /> }<br /> }<br /> <br /> var makeClone = function (clonable) {<br /> // clonable = row, tr = superTestVariable<br /> var tr;<br /> if (!cloned.some(isAlreadyCloned(clonable))) {<br /> // if clonable has not been cloned,<br /> // add it to the cloned collection and<br /> // make a clone which is added to the DOM<br /> tr = clonable.cloneNode(true);<br /> clonable.parentNode.insertBefore(tr, clonable);<br /> <br /> cloned.push(clonable);<br /> cloned.push(tr);<br /> }<br /> }<br /> <br /> makeClone(row);<br /> [/CODE]<br /> <br /> </li> <li data-xf-list-type="ol">setAttribute() nicht verwenden und "value" direkt setzen. das funktioniert zwar, allerdings ist damit das erzeugte markup nicht mehr valide.<br /> [CODE]<br /> var tr = row.cloneNode(true);<br /> tr.value = 'copy';<br /> tr.parentNode.insertBefore(tr, row);<br /> [/CODE]</li> </ol><p>persönlich würde ich variante (1) nutzen, die macht vermutlich am wenigsten arbeit und ist genauso valide wie variante (2). beispiel:</p><p>[CODE]</p><p>var isCloned = function (node) {</p><p> return (/\s?copy\b/g).test(node.className);</p><p>}</p><p></p><p>var makeClone = function (clonable) {</p><p> var tr, classes;</p><p> if (!isCloned(clonable)) {</p><p> // if clonable has not been cloned,</p><p> // clone it, split (maybe) existend classnames into a array,</p><p> // add the 'copy' class and concatenate them to a string</p><p> // which is the new classname and add the clone to</p><p> // the DOM</p><p> tr = clonable.cloneNode(true);</p><p> classes = tr.className.split(' ');</p><p> classes.push('copy');</p><p> tr.className = classes.join(' ');</p><p> clonable.parentNode.insertBefore(tr, clonable);</p><p> }</p><p>}</p><p></p><p>makeClone(row);</p><p>[/CODE]</p><p></p><p>hoffe das hilft</p></blockquote><p></p>
[QUOTE="mindraper, post: 2387797, member: 115163"] moinsen, tablerow elemente kennen das value-attribut nicht. aus diesem grund funktioniert "setAttribute" hier nicht. es gibt hier mehrere lösungen, im folgenden beschrieben von "sauberste" zu "unsauberste": [LIST=1] [*]eines der globalen html-attribute verwenden. beispielsweise "title", "class", "data-xxx" oder sonstige der verfügbaren. eine übersicht gibt's hier: [url]https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes[/url] [*]bereits geklonte tr-elemente als referenzvariablen in einem array oder object cachen und vor dem erzeugen eines neuen klons abgleichen, ob schon eine kopie erzeugt wurde. in javascript werden dom-elemente by-reference verglichen, nicht by-value, so dass ein bereits erzeugter klon faktisch immer eindeutig ist und per striktem vergleich (===) abgeglichen werden kann. [CODE]// contains every tr which has already been cloned var cloned = []; var isAlreadyCloned = function (node) { // iterator function to check if the given // node has already been cloned return function (cloned) { return cloned === node; } } var makeClone = function (clonable) { // clonable = row, tr = superTestVariable var tr; if (!cloned.some(isAlreadyCloned(clonable))) { // if clonable has not been cloned, // add it to the cloned collection and // make a clone which is added to the DOM tr = clonable.cloneNode(true); clonable.parentNode.insertBefore(tr, clonable); cloned.push(clonable); cloned.push(tr); } } makeClone(row); [/CODE] [*]setAttribute() nicht verwenden und "value" direkt setzen. das funktioniert zwar, allerdings ist damit das erzeugte markup nicht mehr valide. [CODE] var tr = row.cloneNode(true); tr.value = 'copy'; tr.parentNode.insertBefore(tr, row); [/CODE] [/LIST] persönlich würde ich variante (1) nutzen, die macht vermutlich am wenigsten arbeit und ist genauso valide wie variante (2). beispiel: [CODE] var isCloned = function (node) { return (/\s?copy\b/g).test(node.className); } var makeClone = function (clonable) { var tr, classes; if (!isCloned(clonable)) { // if clonable has not been cloned, // clone it, split (maybe) existend classnames into a array, // add the 'copy' class and concatenate them to a string // which is the new classname and add the clone to // the DOM tr = clonable.cloneNode(true); classes = tr.className.split(' '); classes.push('copy'); tr.className = classes.join(' '); clonable.parentNode.insertBefore(tr, clonable); } } makeClone(row); [/CODE] hoffe das hilft [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ★ = 12, ◇ = 4 und die Hälfte von ★ zu ◇ addiert wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
JavaSript - cloneNode und Werte ändern
Oben