NEWS
Timeout Zeit verkürzen
-
Ich hatte schon befürchtet, dass ich die Aktionen innerhalb des Timeouts kapseln muss um sie an verschiedenen Stellen auszuführen. Hatte gehofft, dass es da eine elegantere Lösung gibtum die Zeit bis zur Ausführung des Timeouts zu verändern, aber was nicht ist ist nicht...
Danke für die Hilfe!
-
@guitardoc sagte in Timeout Zeit verkürzen:
Hatte gehofft, dass es da eine elegantere Lösung gibt
Was soll denn eleganter als ein Funktionsaufruf sein?
Mag ja sein, dass das in Blockly etwas sperrig aussieht.
Aber der Code-Behind sieht dann so ziemlos so aus, wie es die meisten Entwickler machen würden. -
@codierknecht Naja, eine Variante wäre
if timeout läuft setze time vom timeout auf x.
Oder so ähnlich...
-
-
@bahnuhr Ja, aber dann muss ich die Aktionen, die nach dem Timeout kommen, doppelt schreiben oder in einer Funktion kapseln. Das ist kein Problem, nur dachte ich, dass es eine kürzere Möglichkeit gibt.
-
@bahnuhr sagte in Timeout Zeit verkürzen:
und setze einen neuen mit x
Und wenn X = 0 dann braucht's gar keinen timeout.
Dann ruft man direkt den Funktionsblock auf. So wie es @Meister-Mopper und @Asgothian beschrieben haben.Programmierer sind halt von Haus aus faul. Darum schreiben sie sowas in eine Funktion, damit man den Code nur 1x pflegen muss. => "Don't repeat yourself" (Eine der ersten Clean-Code-Regeln).
Nochmal: Das sieht nur in Blockly so sperrig aus. Im (Pseudo-) Code sieht das völlig straight-forward aus:
function MachWas() { //hier wird die eigentliche Funktionalität implementiert } // Fall 1: Mit Timeout on ({id: 'id1'}) { clearTimeout(timeout); timeout = setTimeout({ MachWas(); }, 1000); } // Fall 2: Ohne Timeout on ({id: 'id2'}) { clearTimeout(timeout); MachWas(); }
-
genauso hätte ich es auch gemacht.
Für was ist das?
@codierknecht sagte in Timeout Zeit verkürzen:
timeout = null;
-
@bahnuhr sagte in Timeout Zeit verkürzen:
Für was ist das?
"Pseudo-Code".
Hatte ich einfach aus 'nem Blockly übernommen. Kann zur Vereinfachung auch weg. Korrigiere ich. -
@codierknecht said in Timeout Zeit verkürzen:
Programmierer sind halt von Haus aus faul. Darum schreiben sie sowas in eine Funktion, damit man den Code nur 1x pflegen muss. => "Don't repeat yourself" (Eine der ersten Clean-Code-Regeln).
Alles richtig und ich würde es im direkten Code auch so schreiben. Ich hatte nur gehofft, dass es im Blockly eine Variante gibt um den Timeout einfacher zu steuern, denn Funktionen in Blockly sind für kleinere Anweisungen prima, für größere aber eine Qual, zumal es, wenn ich es richtig sehe, nur maximal eine Ergebnisvariable (also das Ergebnis eines Funktionsaufrufs) gibt. Richtige Prozeduren mit mehreren Rückgabevariablen kann man im Blockly leider nicht schreiben, da müsste man direkt in Javascript schreiben. Und wenn es einigermaßen objektorientiert sein soll, dann gleich in TypeScript. Aber ich hatte das nun mal in Blockly angefangen und keine Lust in JS weiter zu schreiben und alles neu zu strukturieren.
Ist doch alles kein großes Ding - meine Idee die ich dazu hatte geht nicht und ich muss die Prozeduren anders kapseln und aufrufen - alles schick.
-
@guitardoc sagte in Timeout Zeit verkürzen:
Das ist kein Problem, nur dachte ich, dass es eine kürzere Möglichkeit gibt.
wie hattest du es denn früher gemacht?
@guitardoc sagte in Timeout Zeit verkürzen:
Geht das irgendwie? Bestimmt, aber ich habe vergessen wie...
heisst doch, dass du es schon gemacht hattest
-
@homoran Ja, ich hatte vergessen, dass ich es früher auch schon mit gekapselten Prozeduren gemacht hatte und dachte, es gibt eine einfachere Methode...
-
@guitardoc sagte in Timeout Zeit verkürzen:
Richtige Prozeduren mit mehreren Rückgabevariablen kann man im Blockly leider nicht schreiben
Warum nicht? Gib doch ein JSON zurück.
Mehrere Rückgabewerte sind im eigentlichen Sinne ja nicht möglich.
Eine Funktion (eine Prozedur gibt in meiner Welt kein Ergebnis zurück) hat genau 1 Rückgabewert.
Das kann allerdings auch ein record/struct sein ... oder halt ein Objekt, was dann in JS als JSON notiert würde.Rückgabe von Werten über Var/Out-Parameter ist eher 'ne Krücke und unschön.
-
@codierknecht JSON wäre eine Idee, das stimmt. Bin damit nicht ganz so vertraut, daher vergesse ich das JSON immer.