• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

JS function und jQuery

nietaL

NGBler

Registriert
8 Sep. 2013
Beiträge
231
Ort
Exilgullianer
Hey Leute,

ich bekomm die Syntax nicht gepacken. Folgendes funktioniert hervorragend:

[src=javascript]onclick function klappen_politik();

<script>
function klappen_politik()
{
$("#politik").animate({"height": "toggle"}, { duration: 500 });
}
</script>[/src]

Ich möchte die Funktion nun aber für weitere Themen öffnen:

[src=javascript]onclick function klappen('poltik');

<script>
function klappen(thema)
{
XXXXXXX.animate({"height": "toggle"}, { duration: 500 });
}
</script>[/src]

Wie muss die Syntax an der XXXXXXXX-Stelle lauten? Ich krieg es einfach nicht hin, dass er es als Variable und nicht als ID interpretiert.
 

epiphora

aus Plastik
Veteran

Registriert
14 Juli 2013
Beiträge
3.894
Ort
DE-CIX
Wenn es für den übergebenen Parameter thema ein Element mit entsprechender ID gibt, kannst Du es einfach so machen:
[src=javascript]function klappen(thema)
{
$('#' + thema).animate({"height": "toggle"}, { duration: 500 });
}[/src]
 
Zuletzt bearbeitet:

nietaL

NGBler

Registriert
8 Sep. 2013
Beiträge
231
Ort
Exilgullianer
  • Thread Starter Thread Starter
  • #3
oh mann, erschreckend logisch. ich danke dir. funktioniert. Können dieses per jQuery gesetzten Eigenschaften eigentlich auch per if abgerufen werden? Da es serverseitig ist, schlägt es sich ja auf den Quelltext nicht nieder, richtig? Wo werden die Eigenschaften gespeichert? Hier wird ja die HEIGHT geTOGGLEt. Wo steht, wie HEIGHT aktuell gesetzt ist?
 

epiphora

aus Plastik
Veteran

Registriert
14 Juli 2013
Beiträge
3.894
Ort
DE-CIX
Da es serverseitig ist, schlägt es sich ja auf den Quelltext nicht nieder, richtig?
Du meinst sicher clientseitig. Welchen Wert ein Attribut eines Elements oder welche Style-Eigenschaften es aktuell hat, kannst Du zum Beispiel über Firebug für Firefox oder über die Chrome Developer Tools herausfinden.

Toggle ist hierbei kein echter Wert, der zugewiesen wird, sondern lediglich ein Shortcut zum Umschalten. Näheres dazu steht in den jQuery-Docs: http://api.jquery.com/animate/#animation-properties
 

nietaL

NGBler

Registriert
8 Sep. 2013
Beiträge
231
Ort
Exilgullianer
  • Thread Starter Thread Starter
  • #5
natürlich clientseitig ....

Also kann in einem head-javascript gar nichts einbinden, was per if-Abfrage den derzeitigen Status abfragt?

[src=javascript]function klappen(thema)
{
$('#' + thema).animate({"height": "toggle"}, { duration: 500 });

$("#picOne").fadeToggle("slow");
$("#picTwo").fadeToggle("slow");
}[/src]

Der erste Teil öffnet bzw. schließt die jeweilige Themenbox.

Automatisch wird dann ein Hintergrundbild abgedimmt bzw wieder eingeblendet.

So macht das ganz noch wenig Sinn. Ziel ist, dass das Hintergrundbild gedimmt bleibt, solange auch nur eine Themenbox aufgeklappt ist. Geht das?

Auf die Bilder klicken: http://www.successi.de/_COMMENTARII/
 

epiphora

aus Plastik
Veteran

Registriert
14 Juli 2013
Beiträge
3.894
Ort
DE-CIX
Doch, das geht natürlich. Unabhängig davon, wo der Code für Dein Javascript steht.

Dann solltest Du aber besser nicht mit toggle arbeiten, sondern die Abfragen einzeln machen und den Hintergrund dann entsprechend verdunkeln.

Möglich ist alles, vielleicht wäre es besser, wenn Du Dich mal mit den Javascript-Grundlagen vertraut machst und Dir die Funktionsweise von jQuery ein wenig verdeutlichst.
 

LemonDrops

Neu angemeldet

Registriert
20 Juli 2013
Beiträge
543
@nietaL: kleiner Tipp für Js.

Schlechte Idee:
[src=javascript]
function ()
{
/* ... */
}
[/src]

Gute Idee:
[src=javascript]
function () {
/* ... */
}
[/src]


Die Geschweifte Klammer eines Codeblock gehört noch mit auf die Selbe Zeile, dass es in diesem Fall eine Funktion ist, ist willkürlich. Javascript setzt fehlende Semikolons automatisch. Darum kann so etwas passieren:


Funktioniert wie erwartet:
[src=javascript]
function (){

return {
foo:'bar'
}
}
[/src]

Funktioniert nicht wie erwartet:
[src=javascript]
function (){

return
{
foo:'bar'
}
}
[/src]

Es gibt also nur einen weg den Code Systematisch gleich zu schreiben.
 
Oben