Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Variable in Scheduler nutzen

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    SOLVED Variable in Scheduler nutzen

    This topic has been deleted. Only users with topic management privileges can see it.
    • padrino
      padrino Most Active @paul53 last edited by

      @paul53

      Sorry, so ganz blick ich es dann doch nicht. 😞
      Das ist dann ja ein Trigger und daran kann ich ja keine Änderungen mehr zur Laufzeit machen.
      Eine Möglichkeit, die ich sehen würde, wäre das Skript immer bei Bedarf zu starten, sodass dann aktuelle Werte aus Datenpunkten gelesen und als "cron string" verwendet werden?
      Das scheint mir aber nicht sehr sauber oder gewollt. 😌

      paul53 1 Reply Last reply Reply Quote 0
      • paul53
        paul53 @padrino last edited by

        @padrino sagte:

        daran kann ich ja keine Änderungen mehr zur Laufzeit machen.

        Änderungen zur Laufzeit durch Änderung der Uhrzeit in einem Datenpunkt geht z.B. so:

        Blockly_temp.JPG

        1 Reply Last reply Reply Quote 1
        • padrino
          padrino Most Active last edited by

          Danke!
          Das ist echt clever.
          Verstehen tu ich's problemlos, aber auf sowas wäre ich im Leben nicht selbst gekommen. 😞

          1 Reply Last reply Reply Quote 0
          • Matthias_
            Matthias_ @paul53 last edited by Matthias_

            @paul53
            Hallo, gibt es eine effizientere Lösung falls man mehrere Variablen für idWeckzeit braucht als nur eine oder zwei?
            LG Matthias

            Asgothian 1 Reply Last reply Reply Quote 0
            • Asgothian
              Asgothian Developer @Matthias_ last edited by

              @matthias_ effizienter als je einen shedule für jeden Timer ? Nein.

              A.

              Matthias_ 1 Reply Last reply Reply Quote 0
              • Matthias_
                Matthias_ @Asgothian last edited by

                @asgothian said in Variable in Scheduler nutzen:

                effizienter als je einen shedule für jeden Timer ? Nein.

                ok, danke trotzdem
                dachte man kann vielleicht mit mehren Arrays arbeiten...

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Matthias_ last edited by

                  @matthias_ sagte: dachte man kann vielleicht mit mehren Arrays arbeiten...

                  Ja, aber nicht mit Blockly.

                  Matthias_ 1 Reply Last reply Reply Quote 0
                  • Matthias_
                    Matthias_ @paul53 last edited by Matthias_

                    @paul53 @paul53 Sorry hab's nicht dazugeschrieben...
                    Ich Programmiere mit JS (bin aber noch ein Anfänger)

                    Asgothian 1 Reply Last reply Reply Quote 0
                    • Asgothian
                      Asgothian Developer @Matthias_ last edited by Asgothian

                      @matthias_

                      Da gibt es einen einfachen trick. Durch das Nutzen der ID deines Einstell-states als Key in einem "key/value store" kannst du die einzelnen Shedules sauber behalten. Das einzige was du machen musst um einen weiteren Alarm hinzu zu fügen ist im on einen weiteren state mit anzugeben und in der Funktion TriggerAlertFor die Aktion die für diesen State geplant ist zu definieren.

                      Dann brauchst du nicht mehrere Arrays.

                      let schedules = {};
                      
                      function TriggerAlertFor(string id)
                      {
                        // hier musst du die jeweilige Aktion für das aktivieren des alarms auswählen - basiert auf dem übergebenen String.
                        //Der String der hier ankommt ist immer die ID des State mit dem du die Zeit für den Alarm festlest.
                      }
                      
                      on({id:"first_timer_dp", "second_timer_dp"}, change:'ne'}, function (obj) {
                        const alert = obj._id;
                        if (schedules[alert]) clearShedule(schedules[alert]);
                        const times = obj.state.val.split(':');
                        if times.length < 2 return;
                        schedules[obj._id] = schedule('* * '+times[0] + ' ' + times[1],function() { TriggerAlertFor(alert)}); 
                      });
                      
                      Matthias_ 1 Reply Last reply Reply Quote 1
                      • Matthias_
                        Matthias_ @Asgothian last edited by Matthias_

                        @asgothian Danke Vielmals 😊
                        Wäre nicht drauf gekommen, dass man das so einfach lösen kann ... Danke😁

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        858
                        Online

                        31.8k
                        Users

                        80.0k
                        Topics

                        1.3m
                        Posts

                        6
                        21
                        2074
                        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