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: divs anzeigen / ausblenden funktioniert leider nur teilweise
Beitrag
<blockquote data-quote="mindraper" data-source="post: 1942541" data-attributes="member: 115163"><p><strong>AW: Javascript: divs anzeigen / ausblenden funktioniert leider nur teilweise</strong></p><p></p><p>i'm back <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>schon älter, aber ich geb' hier dennoch mal meinen senf ab, um die letzte frage vom TE zu beantworten.</p><p></p><p>@buyas:</p><p>nein. es macht performanceseitig überhaupt keinen unterschied, ob du ein element auf display:hidden; oder visibility:hidden; setzt. oder der unterschied ist so signifikant gering, dass das menschliche auge ihn unmöglich wahrnehmen würde.</p><p></p><p>die zwei functions von pitTi funktionieren, weil deine abfrage am beginn deiner show() und hide() functions fehlerhaft war/ist und pitTi diese abfrage einfach nicht in seine variante übernommen hat.</p><p>wie cebito schon gesagt hat, bedeutet ein vergleich mit != oder !== soviel wie "ist nicht gleich" ( in diesem fall wäre die zweite variante strenger als die erste ).</p><p>das soll heissen, dass du beispielsweise in deiner show-function anstatt</p><p></p><p>function show( divid ){</p><p> if( document.getElementById( divid ).style.display != 'hidden' ){</p><p> document.getElementById( divid ).style.display = 'block';</p><p> }</p><p>}</p><p></p><p>die if-abfrage auf folgende art schreiben müsstest</p><p></p><p>function show( divid ){</p><p> if( document.getElementById( divid ).style.display === 'hidden' ){</p><p> document.getElementById( divid ).style.display = 'block';</p><p> }</p><p>}</p><p></p><p>falls du dir wirklich gedanken machen solltest, was die performance angeht, dann noch ein tipp:</p><p>vermeide möglichst, das dokument ständig nach einzelnen oder mehreren elementen zu durchsuchen. dass soll heissen: alleine in show() wird das dokument ja 2mal nach einem element mit der übergebenen id ( siehe "divid" ) durchsucht. bei einer suche nach id sollte das nicht sonderlich ins gewicht fallen, anders sieht es aus, wenn du nach elementen mit class suchst und einen browser unterstützen willst, der weder document.getElementsByClassName noch document.querySelectorAll unterstützt ( beispielsweise der MSIE 7 ). in diesem fall müsstest du dir nämlich eine eigene function bauen, die sich zunächst ALLE elemente des dokumentes holt und diese in einer schleife durchläuft und die entsprechenden rausfiltert. z. b. sowas:</p><p></p><p>[PHP]</p><p>// getByClass ist, falls verfügbar, eine native browsermethode, sonst eine eigene function</p><p>var getByClass = function( classname ){</p><p> </p><p> // gibt es eine native browsermethode? dann nutze diese</p><p> if( typeof document.getElementsByClassName !== 'undefined' ){</p><p> return document.getElementsByClassName( classname );</p><p> }</p><p> </p><p> // keine native methode vorhanden. eigene implementierung</p><p> // deklarieren von variablen. allElems sind ALLE im document enthaltenen dom-elemente mit nodeType === 1</p><p> var i, j, clnm = new RegExp( '\\b' + classname + '\\b' ),</p><p> ret = [],</p><p> allElems = document.all || document.getElementsByTagName( '*' );</p><p> </p><p> // allElems durchsuchen und bei treffer herausfiltern</p><p> for( i = 0; i < allElems.length; i = i+1 ){</p><p> if( clnm.test( allElems[i].className ) ){</p><p> ret.push( allElems[i] );</p><p> }</p><p> }</p><p> </p><p> // array mit gefundenen elementen oder leeres array bei keinem fund zurückgeben</p><p> return ret;</p><p>};</p><p>[/PHP]</p><p></p><p>wie du dir vorstellen kannst, dauert es länger, ALLE dom-knoten zu durchsuchen, als nur ein einzelnes element zu finden via id. damit der browser nun nicht jedesmal alle knoten durchlaufen muss, könntest du die entsprechenden elemente in einer variablen speichern und mit dieser arbeiten. kurz gesagt, würde z. b. show dann so aussehen:</p><p></p><p>function show( divid ){</p><p> var div = document.getElementById( divid );</p><p> if( div.style.display === 'none' ){</p><p> div.style.display = 'block';</p><p> }</p><p>}</p><p></p><p>um es noch schneller zu bekommen, könntest du diese variablen sogar in deinem falle global verfügbar machen:</p><p></p><p>var div_1 = document.getElementById( 'div1' ),</p><p> div_2 = document.getElementById( 'div2' );</p><p></p><p>function show(){</p><p> if( this.style.display === 'none' ){</p><p> this.style.display = 'block';</p><p> }</p><p>}</p><p></p><p>div_1.onclick = show;</p><p>div_2.onclick = show;</p><p></p><p>eigentlich bin ich ja gegen spaghetti-code und das setzen von globalen variablen aber OK <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>hoffe das hilft</p></blockquote><p></p>
[QUOTE="mindraper, post: 1942541, member: 115163"] [b]AW: Javascript: divs anzeigen / ausblenden funktioniert leider nur teilweise[/b] i'm back :) schon älter, aber ich geb' hier dennoch mal meinen senf ab, um die letzte frage vom TE zu beantworten. @buyas: nein. es macht performanceseitig überhaupt keinen unterschied, ob du ein element auf display:hidden; oder visibility:hidden; setzt. oder der unterschied ist so signifikant gering, dass das menschliche auge ihn unmöglich wahrnehmen würde. die zwei functions von pitTi funktionieren, weil deine abfrage am beginn deiner show() und hide() functions fehlerhaft war/ist und pitTi diese abfrage einfach nicht in seine variante übernommen hat. wie cebito schon gesagt hat, bedeutet ein vergleich mit != oder !== soviel wie "ist nicht gleich" ( in diesem fall wäre die zweite variante strenger als die erste ). das soll heissen, dass du beispielsweise in deiner show-function anstatt function show( divid ){ if( document.getElementById( divid ).style.display != 'hidden' ){ document.getElementById( divid ).style.display = 'block'; } } die if-abfrage auf folgende art schreiben müsstest function show( divid ){ if( document.getElementById( divid ).style.display === 'hidden' ){ document.getElementById( divid ).style.display = 'block'; } } falls du dir wirklich gedanken machen solltest, was die performance angeht, dann noch ein tipp: vermeide möglichst, das dokument ständig nach einzelnen oder mehreren elementen zu durchsuchen. dass soll heissen: alleine in show() wird das dokument ja 2mal nach einem element mit der übergebenen id ( siehe "divid" ) durchsucht. bei einer suche nach id sollte das nicht sonderlich ins gewicht fallen, anders sieht es aus, wenn du nach elementen mit class suchst und einen browser unterstützen willst, der weder document.getElementsByClassName noch document.querySelectorAll unterstützt ( beispielsweise der MSIE 7 ). in diesem fall müsstest du dir nämlich eine eigene function bauen, die sich zunächst ALLE elemente des dokumentes holt und diese in einer schleife durchläuft und die entsprechenden rausfiltert. z. b. sowas: [PHP] // getByClass ist, falls verfügbar, eine native browsermethode, sonst eine eigene function var getByClass = function( classname ){ // gibt es eine native browsermethode? dann nutze diese if( typeof document.getElementsByClassName !== 'undefined' ){ return document.getElementsByClassName( classname ); } // keine native methode vorhanden. eigene implementierung // deklarieren von variablen. allElems sind ALLE im document enthaltenen dom-elemente mit nodeType === 1 var i, j, clnm = new RegExp( '\\b' + classname + '\\b' ), ret = [], allElems = document.all || document.getElementsByTagName( '*' ); // allElems durchsuchen und bei treffer herausfiltern for( i = 0; i < allElems.length; i = i+1 ){ if( clnm.test( allElems[i].className ) ){ ret.push( allElems[i] ); } } // array mit gefundenen elementen oder leeres array bei keinem fund zurückgeben return ret; }; [/PHP] wie du dir vorstellen kannst, dauert es länger, ALLE dom-knoten zu durchsuchen, als nur ein einzelnes element zu finden via id. damit der browser nun nicht jedesmal alle knoten durchlaufen muss, könntest du die entsprechenden elemente in einer variablen speichern und mit dieser arbeiten. kurz gesagt, würde z. b. show dann so aussehen: function show( divid ){ var div = document.getElementById( divid ); if( div.style.display === 'none' ){ div.style.display = 'block'; } } um es noch schneller zu bekommen, könntest du diese variablen sogar in deinem falle global verfügbar machen: var div_1 = document.getElementById( 'div1' ), div_2 = document.getElementById( 'div2' ); function show(){ if( this.style.display === 'none' ){ this.style.display = 'block'; } } div_1.onclick = show; div_2.onclick = show; eigentlich bin ich ja gegen spaghetti-code und das setzen von globalen variablen aber OK :) hoffe das hilft [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 5, ▼ = 2 und ■ = 7, was ist ▲ × ▼ + ■?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
Javascript: divs anzeigen / ausblenden funktioniert leider nur teilweise
Oben