Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Timeout Zeit verkürzen

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Timeout Zeit verkürzen

    This topic has been deleted. Only users with topic management privileges can see it.
    • bahnuhr
      bahnuhr Forum Testing Most Active @guitardoc last edited by

      @guitardoc

      Na, dann mach dies doch.

      Lösche den aktuellen Timeout und setze einen neuen mit x.

      G Codierknecht 2 Replies Last reply Reply Quote 0
      • G
        guitardoc @bahnuhr last edited by

        @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.

        Homoran 1 Reply Last reply Reply Quote 0
        • Codierknecht
          Codierknecht Developer Most Active @bahnuhr last edited by Codierknecht

          @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();
          }
          
          bahnuhr G 2 Replies Last reply Reply Quote 0
          • bahnuhr
            bahnuhr Forum Testing Most Active @Codierknecht last edited by bahnuhr

            genauso hätte ich es auch gemacht.

            Für was ist das?

            @codierknecht sagte in Timeout Zeit verkürzen:

            timeout = null;

            Codierknecht 1 Reply Last reply Reply Quote 0
            • Codierknecht
              Codierknecht Developer Most Active @bahnuhr last edited by

              @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.

              1 Reply Last reply Reply Quote 0
              • G
                guitardoc @Codierknecht last edited by

                @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.

                Codierknecht 1 Reply Last reply Reply Quote 0
                • Homoran
                  Homoran Global Moderator Administrators @guitardoc last edited by

                  @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 🤔

                  G 1 Reply Last reply Reply Quote 0
                  • G
                    guitardoc @Homoran last edited by

                    @homoran Ja, ich hatte vergessen, dass ich es früher auch schon mit gekapselten Prozeduren gemacht hatte und dachte, es gibt eine einfachere Methode...

                    1 Reply Last reply Reply Quote 0
                    • Codierknecht
                      Codierknecht Developer Most Active @guitardoc last edited by

                      @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.

                      G 1 Reply Last reply Reply Quote 0
                      • G
                        guitardoc @Codierknecht last edited by

                        @codierknecht JSON wäre eine Idee, das stimmt. Bin damit nicht ganz so vertraut, daher vergesse ich das JSON immer.

                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        565
                        Online

                        32.0k
                        Users

                        80.3k
                        Topics

                        1.3m
                        Posts

                        6
                        16
                        501
                        Loading More Posts
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes
                        Reply
                        • Reply as topic
                        Log in to reply
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                        The ioBroker Community 2014-2023
                        logo