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. JavaScript
  5. setState()-Aufrufe haben immer ack == true

NEWS

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

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

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

setState()-Aufrufe haben immer ack == true

Scheduled Pinned Locked Moved JavaScript
15 Posts 4 Posters 1.1k Views 2 Watching
  • 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.
  • T ticaki

    @paul53

    müsste man da nicht noch zusätzlich auf from testen?

    haus-automatisierungH Offline
    haus-automatisierungH Offline
    haus-automatisierung
    Developer Most Active
    wrote on last edited by
    #6

    @ticaki sagte in setState()-Aufrufe haben immer ack == true:

    müsste man da nicht noch zusätzlich auf from testen?

    from wird in diesem Fall immer zigbee.0 sein (für bestätigte Werte). Und javascript.0 für unbestätigte Werte. Es kommt also stark drauf an, was genau man eigentlich wissen möchte und wann man eine Aktion auslösen will.

    In diesem Fall sollte man die Darstellung in VIS wohl nur dann "nachziehen", wenn die Aktion auch wirklich ausgeführt wurde (= bestätigt ist). Und nicht dann, wenn die Aktion angestoßen wurde.

    PS: Eigene Datenpunkte sollte man bestätigt setzen. Also

    setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
    

    Den Vergleich mit true kann man sich schenken:

        if (obj.state.val) {
            setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
        } else {
            setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF', true);
        }
    

    Und dann könnte man das auch komplett kürzen:

    setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
    

    🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
    🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
    📚 Meine inoffizielle ioBroker Dokumentation

    T 1 Reply Last reply
    0
    • paul53P paul53

      @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

      Kann man, aber

      on({id: 'zigbee.0.dc8e95fffe15d81a.state', ack: true, change: 'ne'}
      

      sollte ausreichen, da bei Bestätigung der Änderung aus Vis oder Javascript keine Wertänderung erfolgt, denn diese erfolgte vorher unbestätigt.

      S Offline
      S Offline
      selector
      wrote on last edited by
      #7

      Erstmal danke für die Posts,

      @paul53 said in setState()-Aufrufe haben immer ack == true:

      sollte ausreichen, da bei Bestätigung der Änderung aus Vis oder Javascript keine Wertänderung erfolgt, denn diese erfolgte vorher unbestätigt.

      das war auch meine Annahme.

      @paul53

      Auch das hatte ich schon ausprobiert. Es wird aber immer mit ack=true bestätigt, egal ob ich

      setState([object-path], true) oder
      setState([object-path], true, false) oder
      setState([object-path], true, false, ()=>{})

      aufrufe.

      Den Trigger auf 'ne' Ändern hilft, nicht, das bestimmt ja nur ob der Event-Handler nur aufgerufen wird, wenn eine Änderung zum Vor-Zustand erfolgt. Das kann bei mir sowohl durch den Manuellen Taster, als auch durch VIS sein.

      from ist, wie @haus-automatisierung schon gesagt hat, immer gleich.

      PS: Eigene Datenpunkte sollte man bestätigt setzen. Also

      Warum sollten die immer bestätigt gesetzt werden? Ich hätte jetzt gedacht, dass man über das ack-Flag nur steuert, ob der dahinterliegende Event-Mechanismus getriggert wird. Aber ich gucke mir jetzt erstmal das verlinkte Video an. Danke für den Link.

      1 Reply Last reply
      0
      • haus-automatisierungH haus-automatisierung

        @ticaki sagte in setState()-Aufrufe haben immer ack == true:

        müsste man da nicht noch zusätzlich auf from testen?

        from wird in diesem Fall immer zigbee.0 sein (für bestätigte Werte). Und javascript.0 für unbestätigte Werte. Es kommt also stark drauf an, was genau man eigentlich wissen möchte und wann man eine Aktion auslösen will.

        In diesem Fall sollte man die Darstellung in VIS wohl nur dann "nachziehen", wenn die Aktion auch wirklich ausgeführt wurde (= bestätigt ist). Und nicht dann, wenn die Aktion angestoßen wurde.

        PS: Eigene Datenpunkte sollte man bestätigt setzen. Also

        setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
        

        Den Vergleich mit true kann man sich schenken:

            if (obj.state.val) {
                setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
            } else {
                setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF', true);
            }
        

        Und dann könnte man das auch komplett kürzen:

        setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
        
        T Do not disturb
        T Do not disturb
        ticaki
        wrote on last edited by ticaki
        #8

        @haus-automatisierung

        Mein Gedanke dabei war das man von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (z.B. Relais ähnlich shelly 1)

        Edit: Beispiel geändert

        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

        Spenden

        paul53P 1 Reply Last reply
        0
        • T ticaki

          @haus-automatisierung

          Mein Gedanke dabei war das man von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (z.B. Relais ähnlich shelly 1)

          Edit: Beispiel geändert

          paul53P Offline
          paul53P Offline
          paul53
          wrote on last edited by paul53
          #9

          @ticaki sagte: von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (taster, schalter usw)

          ... zusammen mit Bestätigung. Wenn die Änderung per Javascript, Vis oder Admin erfolgt, bekommt man auch change: 'ne' von "zigbee.0", aber unbestätigt.

          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

          S T 2 Replies Last reply
          0
          • paul53P paul53

            @ticaki sagte: von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (taster, schalter usw)

            ... zusammen mit Bestätigung. Wenn die Änderung per Javascript, Vis oder Admin erfolgt, bekommt man auch change: 'ne' von "zigbee.0", aber unbestätigt.

            S Offline
            S Offline
            selector
            wrote on last edited by
            #10

            ok, danke, ich weiß jetzt was mein Denkfehler war und warum eigene Datenpunkt im Gegensatz von Datenpunkten von Adaptern Bestätigt gesetzt werden sollten, das Video hat mir geholfen und. Problem war

            1. Ich setze den Datenpunkt unbestätigt
            2. Der Zigbee-Adapter nimmt das zum anlass den Schalter zu schalten
            3. und sendet ein bestätigtes Event, welches ich dann abgefangen habe
            1 Reply Last reply
            0
            • paul53P paul53

              @ticaki sagte: von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (taster, schalter usw)

              ... zusammen mit Bestätigung. Wenn die Änderung per Javascript, Vis oder Admin erfolgt, bekommt man auch change: 'ne' von "zigbee.0", aber unbestätigt.

              T Do not disturb
              T Do not disturb
              ticaki
              wrote on last edited by ticaki
              #11

              @paul53

              change: 'ne' löst nur aus wenn sich der Wert ändert .

              "ne" (not equal) New value must be not equal to the old one (state.val != oldState.val) If pattern is id-string this value is used by default

              und nur durch das bestätigen ändert sich ja nicht der Wert... oder hat sich da was geändert?

              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

              Spenden

              paul53P 1 Reply Last reply
              0
              • T ticaki

                @paul53

                change: 'ne' löst nur aus wenn sich der Wert ändert .

                "ne" (not equal) New value must be not equal to the old one (state.val != oldState.val) If pattern is id-string this value is used by default

                und nur durch das bestätigen ändert sich ja nicht der Wert... oder hat sich da was geändert?

                paul53P Offline
                paul53P Offline
                paul53
                wrote on last edited by paul53
                #12

                @ticaki sagte: und nur durch das bestätigen ändert sich ja nicht der Wert...

                Das war meine Aussage. Nur, wenn sich der Wert durch manuelle Betätigung vor Ort ändert, kommen change: 'ne', ack: true von "zigbee.0" gleichzeitig.

                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

                S 1 Reply Last reply
                0
                • T ticaki

                  @paul53

                  müsste man da nicht noch zusätzlich auf from testen?

                  paul53P Offline
                  paul53P Offline
                  paul53
                  wrote on last edited by paul53
                  #13

                  @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

                  Will man nur eine Trigger-Schleife verhindern, sollte man from testen:

                  on({id: 'zigbee.0.dc8e95fffe15d81a.state', change: 'ne', fromNe: 'system.adapter.javascript.0'}, function (obj) {
                      console.log('manual mirrow state change to: ' + obj.state.val)
                      console.log(obj)
                      setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
                  });
                  

                  EDIT: So kommt auch eine Änderung per Admin (Tab "Objekte") in der Visualisierung an.

                  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

                  T 1 Reply Last reply
                  0
                  • paul53P paul53

                    @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

                    Will man nur eine Trigger-Schleife verhindern, sollte man from testen:

                    on({id: 'zigbee.0.dc8e95fffe15d81a.state', change: 'ne', fromNe: 'system.adapter.javascript.0'}, function (obj) {
                        console.log('manual mirrow state change to: ' + obj.state.val)
                        console.log(obj)
                        setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
                    });
                    

                    EDIT: So kommt auch eine Änderung per Admin (Tab "Objekte") in der Visualisierung an.

                    T Do not disturb
                    T Do not disturb
                    ticaki
                    wrote on last edited by
                    #14

                    @paul53
                    Jetzt passt es, habs dann wohl falsch gelesen. Ich benutze from/fromNe im Kontext von Shellys um Automatismen zu deaktivieren.

                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                    Spenden

                    1 Reply Last reply
                    0
                    • paul53P paul53

                      @ticaki sagte: und nur durch das bestätigen ändert sich ja nicht der Wert...

                      Das war meine Aussage. Nur, wenn sich der Wert durch manuelle Betätigung vor Ort ändert, kommen change: 'ne', ack: true von "zigbee.0" gleichzeitig.

                      S Offline
                      S Offline
                      selector
                      wrote on last edited by
                      #15

                      @paul53 said in setState()-Aufrufe haben immer ack == true:

                      @ticaki sagte: und nur durch das bestätigen ändert sich ja nicht der Wert...

                      Das war meine Aussage. Nur, wenn sich der Wert durch manuelle Betätigung vor Ort ändert, kommen change: 'ne', ack: true von "zigbee.0" gleichzeitig.

                      Ja, danke nochmal. Auch das ist korrekt, da hatte ich auch erst einen Denkfehler.

                      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

                      273

                      Online

                      32.7k

                      Users

                      82.6k

                      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