Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Array "undefined" und obj.deviceID "null" bei Trigger

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    1.2k

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    663

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    1.2k

Array "undefined" und obj.deviceID "null" bei Trigger

Geplant Angeheftet Gesperrt Verschoben JavaScript
4 Beiträge 2 Kommentatoren 256 Aufrufe 1 Beobachtet
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • PhlixxP Offline
    PhlixxP Offline
    Phlixx
    schrieb am zuletzt editiert von
    #1

    Hallo Community,

    brauche Eure Hilfe, stehe auf dem Schlauch.

    Hintergrund:
    Ich erstelle in einem Skript mit Start des Skripts ein Array von Datenpunkten, um darauf jeweils einen Listener zu registrieren. Das funktioniert ("registered 4 subscriptions").

    Mit Auslösen des Triggers (Wert 3)

    • hat obj.newState.val den Wert 3 (prima)
    • ist obj.objectID aber null und
    • thermostateTrigger[i] undefined.

    Was kann ich tun? Kann ich thermostateTrigger[i] irgendwie persistent zur Laufzeit bekommen, dass die function() bei Aufruf ihre banalen Befehle ausführen kann?

    Danke!
    Phlixx

    javascript.0	2020-10-23 10:42:43.147	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: Countdown Trigger: undefined-null, Wert:3
    javascript.0	2020-10-23 10:42:40.110	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: registered 4 subscriptions and 0 schedules
    javascript.0	2020-10-23 10:42:40.110	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.JMD301xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
    javascript.0	2020-10-23 10:42:40.109	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.MEQ145xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
    javascript.0	2020-10-23 10:42:40.107	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.MEQ145xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
    javascript.0	2020-10-23 10:42:40.106	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.JMD300xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
    
    
    var thermostate = new Array('maxcul.0.JMD300xxxx','maxcul.0.MEQ145xxxx','maxcul.0.MEQ145xxxx','maxcul.0.JMD301xxxx');
    var thermostateTrigger = new Array();
    
    for (var i = 0;i <thermostate.length;i++) {
        thermostateTrigger[i] = thermostate[i]+'.mode';
        createState(thermostateTrigger[i]+'.countdown', 300);
        createState(thermostateTrigger[i]+'.afterCount', false);
        createState(thermostateTrigger[i]+'.countTrigger', false);
    
        on(thermostateTrigger[i], function (obj) {
        log ('Countdown Trigger: '+thermostateTrigger[i]+'-'+obj.deviceId+', Wert:'+obj.newState.val);
        if (obj.newState.val === 3) {
            setState(thermostateTrigger[i]+'.countdown', 300);
            setState(thermostateTrigger[i]+'.countTrigger', true);
            count(thermostateTrigger[i]);
        }    
    });
    }
    
    function count(thermostate) {
        setTimeout(function () {
            var timer = getState(thermostate+'.countdown').val;
            if (timer > 1) {
                setState(thermostate+'.countTrigger', false);
                setState(thermostate+'.countdown', timer - 1);
                count(thermostate);
            } else {
                setState(thermostate+'.countdown', 0);
                setState(thermostate+'.afterCount', true);
            }
        }, 1000);
    }
    
    

    EQ-3 MAX, HUE, TRADFRI, OSRAM
    Raspberry Pi 4 (Raspian Buster, Docker, ioBroker, Deconz, MAXCUL, PiVCCU)

    PhlixxP 1 Antwort Letzte Antwort
    0
    • PhlixxP Phlixx

      Hallo Community,

      brauche Eure Hilfe, stehe auf dem Schlauch.

      Hintergrund:
      Ich erstelle in einem Skript mit Start des Skripts ein Array von Datenpunkten, um darauf jeweils einen Listener zu registrieren. Das funktioniert ("registered 4 subscriptions").

      Mit Auslösen des Triggers (Wert 3)

      • hat obj.newState.val den Wert 3 (prima)
      • ist obj.objectID aber null und
      • thermostateTrigger[i] undefined.

      Was kann ich tun? Kann ich thermostateTrigger[i] irgendwie persistent zur Laufzeit bekommen, dass die function() bei Aufruf ihre banalen Befehle ausführen kann?

      Danke!
      Phlixx

      javascript.0	2020-10-23 10:42:43.147	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: Countdown Trigger: undefined-null, Wert:3
      javascript.0	2020-10-23 10:42:40.110	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: registered 4 subscriptions and 0 schedules
      javascript.0	2020-10-23 10:42:40.110	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.JMD301xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
      javascript.0	2020-10-23 10:42:40.109	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.MEQ145xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
      javascript.0	2020-10-23 10:42:40.107	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.MEQ145xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
      javascript.0	2020-10-23 10:42:40.106	info	(21842) script.js.Counter.CountdownBoostMaxEQtest: subscribe: {"pattern":{"id":"maxcul.0.JMD300xxxx.mode","change":"ne","q":0},"name":"script.js.Counter.CountdownBoostMaxEQtest"}
      
      
      var thermostate = new Array('maxcul.0.JMD300xxxx','maxcul.0.MEQ145xxxx','maxcul.0.MEQ145xxxx','maxcul.0.JMD301xxxx');
      var thermostateTrigger = new Array();
      
      for (var i = 0;i <thermostate.length;i++) {
          thermostateTrigger[i] = thermostate[i]+'.mode';
          createState(thermostateTrigger[i]+'.countdown', 300);
          createState(thermostateTrigger[i]+'.afterCount', false);
          createState(thermostateTrigger[i]+'.countTrigger', false);
      
          on(thermostateTrigger[i], function (obj) {
          log ('Countdown Trigger: '+thermostateTrigger[i]+'-'+obj.deviceId+', Wert:'+obj.newState.val);
          if (obj.newState.val === 3) {
              setState(thermostateTrigger[i]+'.countdown', 300);
              setState(thermostateTrigger[i]+'.countTrigger', true);
              count(thermostateTrigger[i]);
          }    
      });
      }
      
      function count(thermostate) {
          setTimeout(function () {
              var timer = getState(thermostate+'.countdown').val;
              if (timer > 1) {
                  setState(thermostate+'.countTrigger', false);
                  setState(thermostate+'.countdown', timer - 1);
                  count(thermostate);
              } else {
                  setState(thermostate+'.countdown', 0);
                  setState(thermostate+'.afterCount', true);
              }
          }, 1000);
      }
      
      
      PhlixxP Offline
      PhlixxP Offline
      Phlixx
      schrieb am zuletzt editiert von
      #2

      Oder Kurzfassung:

      Warum komme ich nicht an die deviceID des auslösenden Objekts?

      obj.newState.val --> 3

      obj.deviceID --> null

      Muss ich was in ioBroker umstellen?

      Danke!

      (Das mit dem Array war nur der hilflose Versuch eines Workarounds für obiges Problem

      EQ-3 MAX, HUE, TRADFRI, OSRAM
      Raspberry Pi 4 (Raspian Buster, Docker, ioBroker, Deconz, MAXCUL, PiVCCU)

      paul53P 1 Antwort Letzte Antwort
      0
      • PhlixxP Phlixx

        Oder Kurzfassung:

        Warum komme ich nicht an die deviceID des auslösenden Objekts?

        obj.newState.val --> 3

        obj.deviceID --> null

        Muss ich was in ioBroker umstellen?

        Danke!

        (Das mit dem Array war nur der hilflose Versuch eines Workarounds für obiges Problem

        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von paul53
        #3

        @Phlixx sagte:

        Warum komme ich nicht an die deviceID des auslösenden Objekts?

        obj.deviceId funktioniert nur bei einer Ordnerstruktur "device.channel.state". Versuche es mal mit obj.channelId.

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: Asus PN 42 / N100 / 8 GB / 500 GB

        PhlixxP 1 Antwort Letzte Antwort
        0
        • paul53P paul53

          @Phlixx sagte:

          Warum komme ich nicht an die deviceID des auslösenden Objekts?

          obj.deviceId funktioniert nur bei einer Ordnerstruktur "device.channel.state". Versuche es mal mit obj.channelId.

          PhlixxP Offline
          PhlixxP Offline
          Phlixx
          schrieb am zuletzt editiert von Phlixx
          #4

          @paul53 Darauf muss man mal kommen.
          Dann kann das Array zur Laufzeit ja weg ;-)

          Danke Dir, Paul!
          Gruß Phlixx

          Falls jemand auf der Suche vorbei schaut, einfach das Array mit den DeviceIDs der eigenen Geräte füllen. Rest sollte dank @paul53 jetzt so gehen ...

          
          var thermostate = new Array('maxcul.0.JMD300xxxx','maxcul.0.MEQ145xxxx','maxcul.0.MEQ145xxxx','maxcul.0.JMD301xxxx');
          //Array mit den DeviceIDs der eigenen Geräte füllen
          
          for (var i = 0;i <thermostate.length;i++) {
              createState(thermostate[i]+'.countdown', 0); // falls noch nicht existent
              createState(thermostate[i]+'.afterCount', false);
              
              on(thermostate[i]+'.mode', function (obj) { //je DeviceID einen Listener registrieren
                  // geht nur mit obj.channelId, nicht obj.deviceId
                  if (obj.newState.val === 3) {
                      setState(obj.channelId+'.countdown', 300);
                      count(obj.channelId);
                  }    
              });
          }
          
          function count(thermostat) { 
          // mit diesem Sekundentimer (setTimeOut(...,1000) bin ich nicht glücklich, im Frontent sieht es unruhig aus, da die Updates nicht sekündlich kommen... ggs. als Minuten darstellen...
              setTimeout(function () {
                  var timer = getState(thermostat+'.countdown').val;
                  if (timer > 1) {
                      setState(thermostat+'.countdown', timer - 1);
                      count(thermostat);
                  } else {
                      setState(thermostat+'.countdown', 0);
                      setState(thermostat+'.afterCount', true);
                  }
              }, 1000);
          }
          
          

          EQ-3 MAX, HUE, TRADFRI, OSRAM
          Raspberry Pi 4 (Raspian Buster, Docker, ioBroker, Deconz, MAXCUL, PiVCCU)

          1 Antwort Letzte Antwort
          0

          Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

          Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

          Mit deinem Input könnte dieser Beitrag noch besser werden 💗

          Registrieren Anmelden
          Antworten
          • In einem neuen Thema antworten
          Anmelden zum Antworten
          • Älteste zuerst
          • Neuste zuerst
          • Meiste Stimmen


          Support us

          ioBroker
          Community Adapters
          Donate

          401

          Online

          32.9k

          Benutzer

          82.9k

          Themen

          1.3m

          Beiträge
          Community
          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
          ioBroker Community 2014-2025
          logo
          • Anmelden

          • Du hast noch kein Konto? Registrieren

          • Anmelden oder registrieren, um zu suchen
          • Erster Beitrag
            Letzter Beitrag
          0
          • Home
          • Aktuell
          • Tags
          • Ungelesen 0
          • Kategorien
          • Unreplied
          • Beliebt
          • GitHub
          • Docu
          • Hilfe