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. Direkt nach createState setState aufrufen

NEWS

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

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

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

Direkt nach createState setState aufrufen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
4 Beiträge 2 Kommentatoren 411 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.
  • manuxiM Online
    manuxiM Online
    manuxi
    schrieb am zuletzt editiert von
    #1

    Guten Abend,
    ich möchte in einem Script die DPs, falls nicht vorhanden, anlegen und dann befüllen.

    devices.forEach(function(device, index, arr){
        createState(device.idVis, 0, false, StateDefault);
        initStates(device); //hier passieren einige Checks und in späteren Funktionsaufrufen das setState...
    });
    

    Beim ersten Aufruf (ohne erstellten State) bekomme ich ein paar Warnings (außer, ich stelle forceCreation auf true).
    Eine Möglichkeit wäre ja die initStates als callback anzugeben, aber das verringert mmn. die Lesbarkeit.

    Woran liegt das? Ist zum Zeitpunkt von setState der aktualisierte Objektbaum noch nicht bekannt? Lässt sich das Aktualisieren erzwingen?

    Oder gibt es eine andere Möglichkeit? [Timeout (1000ms) habe ich bereits erfolglos probiert...]

    T 1 Antwort Letzte Antwort
    0
    • manuxiM manuxi

      Guten Abend,
      ich möchte in einem Script die DPs, falls nicht vorhanden, anlegen und dann befüllen.

      devices.forEach(function(device, index, arr){
          createState(device.idVis, 0, false, StateDefault);
          initStates(device); //hier passieren einige Checks und in späteren Funktionsaufrufen das setState...
      });
      

      Beim ersten Aufruf (ohne erstellten State) bekomme ich ein paar Warnings (außer, ich stelle forceCreation auf true).
      Eine Möglichkeit wäre ja die initStates als callback anzugeben, aber das verringert mmn. die Lesbarkeit.

      Woran liegt das? Ist zum Zeitpunkt von setState der aktualisierte Objektbaum noch nicht bekannt? Lässt sich das Aktualisieren erzwingen?

      Oder gibt es eine andere Möglichkeit? [Timeout (1000ms) habe ich bereits erfolglos probiert...]

      T Nicht stören
      T Nicht stören
      ticaki
      schrieb am zuletzt editiert von ticaki
      #2

      @manuxi sagte in Direkt nach createState setState aufrufen:

      Guten Abend,
      ich möchte in einem Script die DPs, falls nicht vorhanden, anlegen und dann befüllen.
      Beim ersten Aufruf (ohne erstellten State) bekomme ich ein paar Warnings (außer, ich stelle forceCreation auf true).
      Eine Möglichkeit wäre ja die initStates als callback anzugeben, aber das verringert mmn. die Lesbarkeit.

      Woran liegt das? Ist zum Zeitpunkt von setState der aktualisierte Objektbaum noch nicht bekannt? Lässt sich das Aktualisieren erzwingen?

      Oder gibt es eine andere Möglichkeit? [Timeout (1000ms) habe ich bereits erfolglos probiert...]

      async function main() {
      //hier kopierst du dein ganzes Skript rein
        for ( const device of devices) {
         try {
            await createStateAsync(device.idVis, 0, false, StateDefault);
            initStates(device); //hier passieren einige Checks und in späteren Funktionsaufrufen das setState...
         } catch(e) {
            // Fehler müssen abgefangen werden weil sonst der Nodejs Prozess neustartet.
         } 
        });
      }
      main()
      

      Das ist die einfachste Version - du kopierst dein Skript komplett in die Funktion und kannst dann await benutzen.

      foreach würde ich dann aber nicht benutzen, weil das nötige async die funktionen in der Schleife ab dem await asychron laufen lassen würde.

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      manuxiM 1 Antwort Letzte Antwort
      0
      • T ticaki

        @manuxi sagte in Direkt nach createState setState aufrufen:

        Guten Abend,
        ich möchte in einem Script die DPs, falls nicht vorhanden, anlegen und dann befüllen.
        Beim ersten Aufruf (ohne erstellten State) bekomme ich ein paar Warnings (außer, ich stelle forceCreation auf true).
        Eine Möglichkeit wäre ja die initStates als callback anzugeben, aber das verringert mmn. die Lesbarkeit.

        Woran liegt das? Ist zum Zeitpunkt von setState der aktualisierte Objektbaum noch nicht bekannt? Lässt sich das Aktualisieren erzwingen?

        Oder gibt es eine andere Möglichkeit? [Timeout (1000ms) habe ich bereits erfolglos probiert...]

        async function main() {
        //hier kopierst du dein ganzes Skript rein
          for ( const device of devices) {
           try {
              await createStateAsync(device.idVis, 0, false, StateDefault);
              initStates(device); //hier passieren einige Checks und in späteren Funktionsaufrufen das setState...
           } catch(e) {
              // Fehler müssen abgefangen werden weil sonst der Nodejs Prozess neustartet.
           } 
          });
        }
        main()
        

        Das ist die einfachste Version - du kopierst dein Skript komplett in die Funktion und kannst dann await benutzen.

        foreach würde ich dann aber nicht benutzen, weil das nötige async die funktionen in der Schleife ab dem await asychron laufen lassen würde.

        manuxiM Online
        manuxiM Online
        manuxi
        schrieb am zuletzt editiert von
        #3

        @ticaki vielen Dank für die Info! Werd ich morgen testen!

        manuxiM 1 Antwort Letzte Antwort
        0
        • manuxiM manuxi

          @ticaki vielen Dank für die Info! Werd ich morgen testen!

          manuxiM Online
          manuxiM Online
          manuxi
          schrieb am zuletzt editiert von manuxi
          #4

          @ticaki Funktioniert! Vielen Dank!

          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

          563

          Online

          32.8k

          Benutzer

          82.7k

          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