Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [GELÖST]on({time…..}) Aufruf

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    555

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    5.4k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.4k

[GELÖST]on({time…..}) Aufruf

Scheduled Pinned Locked Moved Skripten / Logik
54 Posts 11 Posters 13.0k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • blauholstenB Offline
    blauholstenB Offline
    blauholsten
    Developer
    wrote on last edited by
    #18

    @paul53:

    Ich habe das mal mit einem Datenpunkt, der die Zeit im Format "hh:mm" enthält, erfolgreich getestet:

    // Zeitsteuerung
    var idt = 'javascript.0.Test.Nachtruhebeginn';
    var timer = null;
    var h; // Stunde
    var m; // Minute
        
    function settimer() {
        if (timer) unsubscribe(timer);
        timer = on({time: {hour: h, minute: m}}, function () {
            log('Nachtruhe beginnt durch Schedulefunktion (Uhrzeit)');
        });
    }
    
    on(idt, function(dp) {
        var t = dp.newState.val.split(":");
        h = parseInt(t[0]);
        m = parseInt(t[1]);
        settimer(); 
        log("Beginn Nachtruhe wird eingestellt " + h + ":" + m);
    });
    
    ```` `  
    

    Das sieht perfekt aus, aber wie bediene ich "var idt = 'javascript.0.Test.Nachtruhebeginn';" im VIS? SET Input Widget?

    Entwickler vom: - Viessman Adapter
    - Alarm Adapter

    1 Reply Last reply
    0
    • M Offline
      M Offline
      mctom
      wrote on last edited by
      #19

      Hallo zusammen,

      ich habe das ganze jetzt mit folgendem Widget umgesetzt: jqui - ctrl - Input + Set-Button.

      Alles funktioniert soweit einwandfrei. - Vielen Dank.

      Allerdings komm ich mit der Formatierung noch nicht so ganz zurecht.

      Im Editor Modus sieht es so aus:
      394_bild1.png

      In Chrome sieht es dann so aus:
      394_bild2.png

      Das Formularfeld wird größer dargestellt. Hat jemand eine Idee was ich hier noch machen kann ?

      Gruß

      Michael

      1 Reply Last reply
      0
      • blauholstenB Offline
        blauholstenB Offline
        blauholsten
        Developer
        wrote on last edited by
        #20

        Wenn ich nicht total blind bin geht die ganze Geschichte doch nicht wirklich…..

        mein Script:

        var nighttime = null;
        var morningtime = null;
        var idvon = 'javascript.0.visstates.nachtruhe.von';
        var idbis = 'javascript.0.visstates.nachtruhe.bis';
        var hvon;
        var mvon;
        var hbis;
        var mbis;
        
        function beginTimer()
        {
            if(nighttime)
            {
                unsubscribe(nighttime);
            }
            nighttime = on({time: {hour: hvon, minute: mvon}}, function()
            {
                setState("javascript.0.visstates.nachtruhe.nachtruhe", true);
                toLog("-->Nachtruhe begonnen", true);
            });
        }
        
        function endTimer()
        {
            if(morningtime)
            {
                unsubscribe(morningtime);
            }
            morningtime = on({time: {hour: hbis, minute: mbis}}, function()
            {
                setState("javascript.0.visstates.nachtruhe.nachtruhe", false);
                toLog("-->Nachtruhe beendet", true);
            });
        }
        
        on(idvon, function(dp) {
            var t = dp.newState.val.split(":");
            hvon = parseInt(t[0]);
            mvon = parseInt(t[1]);
            beginTimer(); 
            log("Beginn Nachtruhe wird eingestellt " + hvon + ":" + mvon);
        });
        
        on(idbis, function(dp) {
            var t = dp.newState.val.split(":");
            hbis = parseInt(t[0]);
            mbis = parseInt(t[1]);
            endTimer(); 
            log("Beginn Nachtruhe wird eingestellt " + hbis + ":" + mbis);
        });
        
        beginTimer();
        endTimer();
        
        

        Jetzt wird einfach die jeweilige Funktion jede Minute ausgeführt, obwohl die on Function vorher gar nicht aufgerufen worden ist, bzw. die Zeiten gar nicht gesetzt sind.

        671_unbenannt1.png
        671_unbenannt.png

        Mach ich was falsch?

        Warum auch immer werden jetzt pünktlich jede Minute beide Funktionen aufgerufen, warum auch immer!!!???????

        Entwickler vom: - Viessman Adapter
        - Alarm Adapter

        1 Reply Last reply
        0
        • M Offline
          M Offline
          mctom
          wrote on last edited by
          #21

          Hi,

          Hast du mal probiert die Zeit in folgendem Format einzugeben: hh:mm und nicht: hh:mm:ss. Das ist ein Unterschied zu mir der mir auf den ersten Blick aufgefallen.

          Gruß

          Michael

          1 Reply Last reply
          0
          • blauholstenB Offline
            blauholstenB Offline
            blauholsten
            Developer
            wrote on last edited by
            #22

            wie mache ich das?

            671_unbenannt.png

            Entwickler vom: - Viessman Adapter
            - Alarm Adapter

            1 Reply Last reply
            0
            • M Offline
              M Offline
              mctom
              wrote on last edited by
              #23

              ich habe jetzt das Widget basic - Input val genommen.

              Hier kann man die Uhrzeit dann manuell eingeben.

              1 Reply Last reply
              0
              • B Offline
                B Offline
                Brati
                wrote on last edited by
                #24

                Hallo,

                irgendwo habe ich einen Fehler im unsubscribe. Die Zeiten werden per Increase Widget verändert, also Stunde +/- 1 und Minuten +/-5. Jetzt habe ich die Zeit von 09:15 Uhr auf 09:00 gestellt, dass ergibt:

                javascript.0	2016-02-11 09:15:00	info	javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++
                javascript.0	2016-02-11 09:10:01	info	javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++
                javascript.0	2016-02-11 09:05:00	info	javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++
                javascript.0	2016-02-11 09:00:00	info	javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++
                

                Also alle 5min wurde beim runterstellen ein Timer eingetragen, aber nicht gelöscht. Kann mir jemand helfen? (State wurde vorher schon definiert, weil eine Standard Zeittabelle vorgegeben ist, die individuell anpassbar sein soll).

                // ##################### ZEITSTEUERUNG #####################
                var FirstTimer = null;
                
                // Aufstehen morgens 
                
                var id_Stunde = "javascript.0.Li_Stunde",
                    id_Minute = "javascript.0.Li_Minute";
                
                function Li_Aufstehen () {
                     // Aufweckvariable setzen
                   log('+++++++++++++++++ Script Test aufstehen ++++++++++++++++++');
                }
                
                function setFirstTimer() {
                    if (FirstTimer) unsubscribe(FirstTimer);
                    FirstTimer = on({
                        time: {
                            hour: parseInt(getState(id_Stunde).val, 10), 
                            minute: parseInt( getState(id_Minute).val, 10)
                        }
                    }, function () {
                       Li_Aufstehen();
                    });
                }
                
                on({id: id_Stunde,change: 'ne'}, function(obj) { 
                    setFirstTimer(); 
                });
                
                on({id: id_Minute, change: 'ne'} , function(obj) {
                    setFirstTimer(); 
                });
                
                setFirstTimer();
                
                

                Grüße

                Brati

                CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

                1 Reply Last reply
                0
                • blauholstenB Offline
                  blauholstenB Offline
                  blauholsten
                  Developer
                  wrote on last edited by
                  #25

                  Hi,

                  das ist bei mir genau so! Leider…

                  Es ist so als würde im "Bauch" alles gespeichert was man eingegeben hat. Sind dann alle Werte abgearbeitet, wird die eigentliche on (time..... Funktion nicht mehr ausgeführt, obwohl die Werte noch in den Datenpunkten stehen.

                  Wollte das verhalten die letzten Tage schon hier Posten, hatte es dann aber vergessen.

                  Entwickler vom: - Viessman Adapter
                  - Alarm Adapter

                  1 Reply Last reply
                  0
                  • B Offline
                    B Offline
                    Brati
                    wrote on last edited by
                    #26

                    @blauholsten:

                    Hi,

                    das ist bei mir genau so! Leider… `

                    Dann müßte ja "Pix" auch diesen Fehler haben, an seiner Idee habe mich orientiert. Der WAF sinkt gewaltig, wenn man später aufstehen will und dann früher und alle 5min geweckt wird lol
                    314_unbenannt.jpg

                    CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

                    1 Reply Last reply
                    0
                    • P Offline
                      P Offline
                      pix
                      wrote on last edited by
                      #27

                      Hallo,

                      Ich bin gerade unterwegs und kann nicht testen. Ich nutze das für meine Rollläden und da klappt es.

                      Gesendet mit Tapatalk

                      ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

                      1 Reply Last reply
                      0
                      • B Offline
                        B Offline
                        Brati
                        wrote on last edited by
                        #28

                        Auch wenn die Zeit erhöht wird? Also später geöffnet wird? Nur dann würde man es merken.

                        Noch läuft es ja als Test bei mir.

                        Gesendet via Tapatalk.

                        CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

                        1 Reply Last reply
                        0
                        • ThisoftT Offline
                          ThisoftT Offline
                          Thisoft
                          wrote on last edited by
                          #29

                          Hallo,

                          hier mal meine Variante zum Thema.

                          on("javascript.0.Weihnacht.Einschaltzeit", function(obj) {
                              clearSchedule(schEin);
                              var StdEin = getState("javascript.0.Weihnacht.Einschaltzeit").val.substr(0,2);
                              var MinEin = getState("javascript.0.Weihnacht.Einschaltzeit").val.substr(3,2);
                              var SchedStrEin = MinEin + ' ' + StdEin + ' * * 1-7';
                              log("Einschaltzeit geändert auf: " + SchedStrEin);
                              schEin = schedule(SchedStrEin, function(){
                                  log("Weihnachtsbeleuchtung ein per schedule");
                                  setState("javascript.0.Weihnacht.Beleuchtung",true,true);});
                          });
                          

                          Ich hab's etwas anders gelöst. Ich weiß nicht, ob "schedule" besser oder schlechter ist als "on" - aber so hat das jedenfalls tadellos funktioniert.

                          Ich weiß nicht, ob es bei Dir evtl. an der if-Bedingung vor dem unsubscribe liegen könnte…?? Ansonsten vielleicht auch mal den time-String vorher zusammensetzen und mit ins log schreiben lassen damit du siehst was da wirklich ankommt...???

                          22 HM-Geräte; PivCCU2 auf RasPi

                          ioBroker-Multihost; Ubuntu-Master auf Intel-Atom und 3 RasPi-Clients

                          1 Reply Last reply
                          0
                          • B Offline
                            B Offline
                            Brati
                            wrote on last edited by
                            #30

                            Morjens, dass mit der if Bedingungen schwebte mir nach dem Aufstehen auch durch den Kopf. Weil sie doch ohne Bedingungen auch keinen Sinn macht, es muss eh bei jeder Änderungen unsubcribe ausgeführt werden. Werde es mal testen. Grüße Brati

                            Gesendet via Tapatalk.

                            CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

                            1 Reply Last reply
                            0
                            • B Offline
                              B Offline
                              Brati
                              wrote on last edited by
                              #31

                              So, habe es jetzt auf Schedule umgestellt und das läuft perfekt. Ich lasse es noch 1 Woche im Log laufen, dann kommt der Echtbetrieb.

                              Vielen Dank.

                              Bei Interesse hier mein Script mit Wochenplan, den man flexibel ändern kann:

                              // ##################### Wochenplan #####################
                              schedule("00 12 * * *", function () {
                              
                              createState("Li_Stunde", 6);
                              createState("Li_Minute", 30);
                              
                              //      Zeitplan  - wird jeden Tag um 12:00 Uhr für nächsten Tag gesetzt
                              //                         M     D     M     D     F    S     S 
                              //                         o     i     i     o     r    a     o
                              //...................................................................
                              var TagStunde = new Array("1",  "2",  "3",  "4",  "5", "12", "12");
                              var TagMinute = new Array("10", "20", "30", "40", "50","00", "00");
                              
                                  var jetzt = new Date();
                                  var tag = jetzt.getDay(); // Achtung Mo = 1, Array beginnt aber bei 0 -> daher nächster Tag
                                  if ( tag == "7" ) 
                                      tag = "0"; 
                                  log ('Weckzeit morgen: ' + TagStunde[tag] + ':' + TagMinute[tag] + ' Uhr '+ "Tag= " + tag);
                                  setState("javascript.0.Li_Stunde",TagStunde[tag]);
                                  setState("javascript.0.Li_Minute",TagMinute[tag]);
                              
                              });
                              
                              // ##################### variable ZEITSTEUERUNG #####################
                              var Li_Auf = "00 12 * * *";
                              
                              on(/^javascript.0.Li_Minute|javascript.0.Li_Stunde$/, function(obj) {
                                  clearSchedule(Li_Auf);
                                  var id_Stunde = getState("javascript.0.Li_Stunde").val,
                              		id_Minute = getState("javascript.0.Li_Minute").val;
                                  var LiAufZeit = id_Minute + ' ' + id_Stunde + ' * * 1-7';
                                  log("Li Aufstehen geändert auf: " + LiAufZeit);
                                  Li_Auf = schedule(LiAufZeit, function(){
                                      log("++++++++++ Test Aufsteh Script +++++ ");
                                   });
                              });
                              
                              

                              CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

                              1 Reply Last reply
                              0
                              • paul53P Offline
                                paul53P Offline
                                paul53
                                wrote on last edited by
                                #32

                                @Brati:

                                irgendwo habe ich einen Fehler im unsubscribe. Die Zeiten werden per Increase Widget verändert, also Stunde +/- 1 und Minuten +/-5. Jetzt habe ich die Zeit von 09:15 Uhr auf 09:00 gestellt, dass ergibt:

                                Code: Alles auswählen

                                javascript.0 2016-02-11 09:15:00 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

                                javascript.0 2016-02-11 09:10:01 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

                                javascript.0 2016-02-11 09:05:00 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

                                javascript.0 2016-02-11 09:00:00 info javascript.0 script.js.Aufwecken_Zeitpunkte: +++++++++++++++++ Script Test aufstehen ++++++++++++++++++

                                Also alle 5min wurde beim runterstellen ein Timer eingetragen, aber nicht gelöscht. `
                                unsubscribe(timer) funktioniert nicht ! Stattdessen muss clearSchedule(timer) verwendet werden:

                                // Zeitsteuerung
                                var idt = 'javascript.0.Test.Nachtruhe';
                                var timer = null;
                                var h; // Stunde
                                var m; // Minute
                                
                                function settimer() {
                                    if (timer) clearSchedule(timer);
                                    timer = on({time: {hour: h, minute: m}}, function () {
                                        log('Nachtruhe beginnt durch Schedulefunktion (Uhrzeit)');
                                    });
                                }
                                
                                on(idt, function(dp) {
                                    var t = dp.newState.val.split(":");
                                    h = parseInt(t[0]);
                                    m = parseInt(t[1]);
                                    settimer(); 
                                    log("Beginn Nachtruhe wird eingestellt " + h + ":" + m);
                                });
                                
                                

                                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                1 Reply Last reply
                                0
                                • paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by
                                  #33

                                  @blauholsten:

                                  Mach ich was falsch?

                                  Warum auch immer werden jetzt pünktlich jede Minute beide Funktionen aufgerufen, warum auch immer!!!??????? `
                                  Die Funktionen beginTimer() und endTimer() dürfen nicht bei Scriptstart aufgerufen werden, da bei Scriptstart die verwendeten Variablen auf null initialisert werden.

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  1 Reply Last reply
                                  0
                                  • paul53P Offline
                                    paul53P Offline
                                    paul53
                                    wrote on last edited by
                                    #34

                                    Hier noch eine Variante mit mehreren (im Beispiel 2) Zeitfunktionen:

                                    // Zeitsteuerung
                                    var idt1 = 'javascript.0.Test.Nachtruhe';
                                    var idt2 = "javascript.0.Test.Aufstehen";
                                    var timer1;
                                    var timer2;
                                    
                                    function getTimeObject(dp) {
                                        var t = dp.newState.val.split(":");
                                        var h = parseInt(t[0]);
                                        var m = parseInt(t[1]);
                                        return {hour: h, minute: m};    
                                    }
                                    
                                    on(idt1, function(dp) {
                                        var t = getTimeObject(dp)
                                        log("Beginn Nachtruhe wird eingestellt " + JSON.stringify(t));
                                        if (timer1) clearSchedule(timer1);
                                        timer1 = on({time: t}, function () {
                                            log('Start Nachtruhe durch Schedulefunktion (Uhrzeit)');
                                        });
                                    });
                                    
                                    on(idt2, function(dp) {
                                        var t = getTimeObject(dp)
                                        log("Aufstehen wird eingestellt " + JSON.stringify(t));
                                        if (timer2) clearSchedule(timer2);
                                        timer2 = on({time: t}, function () {
                                            log('Start Aufstehen durch Schedulefunktion (Uhrzeit)');
                                        });
                                    });
                                    
                                    

                                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                    1 Reply Last reply
                                    0
                                    • B Offline
                                      B Offline
                                      Brati
                                      wrote on last edited by
                                      #35

                                      Na auf die Antworten haben wir doch gewartet. Schedule hat den charmanten Vorteil Tage mit einzubinden. Hab mir noch ein 3. Array eingefügt. Auf jeden Fall gute Ansätze. Danke. Grüße Brati

                                      Gesendet via Tapatalk.

                                      CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

                                      1 Reply Last reply
                                      0
                                      • blauholstenB Offline
                                        blauholstenB Offline
                                        blauholsten
                                        Developer
                                        wrote on last edited by
                                        #36

                                        @paul53:

                                        @blauholsten:

                                        Mach ich was falsch?

                                        Warum auch immer werden jetzt pünktlich jede Minute beide Funktionen aufgerufen, warum auch immer!!!??????? Die Funktionen beginTimer() und endTimer() dürfen nicht bei Scriptstart aufgerufen werden, da bei Scriptstart die verwendeten Variablen auf null initialisert werden.

                                        Hallo,

                                        habe dein zuletzt gesendetes Skript übernommen, haut perfekt hin Danke!

                                        Mir erschließt sich das trotzdem nicht warum die Funktionen im alten Skript jede Minute ausgeführt worden sind. Das Skript wir doch nicht jede Minute aufgerufen?ODER?

                                        Entwickler vom: - Viessman Adapter
                                        - Alarm Adapter

                                        1 Reply Last reply
                                        0
                                        • paul53P Offline
                                          paul53P Offline
                                          paul53
                                          wrote on last edited by
                                          #37

                                          @blauholsten:

                                          Mir erschließt sich das trotzdem nicht warum die Funktionen im alten Skript jede Minute ausgeführt worden sind. Das Skript wir doch nicht jede Minute aufgerufen?ODER? `
                                          Nein., aber durch den Aufruf der Funktionen beim Scriptstart (letzte 2 Zeilen) wird an die on({time: …}-Funktion übergeben

                                          on({time: {hour: null, minute: null}}, ...)
                                          ````, was vermutlich zu dem beobachteten Verhalten führt.

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          606

                                          Online

                                          32.7k

                                          Users

                                          82.5k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe