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. Einsteigerfragen
  4. Automatisierung
  5. JavaScript und Tuya

NEWS

  • Neues YouTube-Video: Visualisierung im Devices-Adapter
    BluefoxB
    Bluefox
    11
    1
    242

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

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    11
    1
    770

JavaScript und Tuya

Geplant Angeheftet Gesperrt Verschoben Automatisierung
5 Beiträge 3 Kommentatoren 518 Aufrufe 2 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.
  • T Offline
    T Offline
    Theophilus
    schrieb am zuletzt editiert von
    #1

    Moin,
    ich messe die Leistung meiner Solaranlage mit einer WLAN-Steckdose. Über den Tuya-Adapter habe ich sie erfolgreich in den ioBroker eingebunden. Nun möchte ich die aktuelle Leistung auslesen und in einem Datenpunkt speichern. Dazu habe ich (abgeleitet von Blockly) folgendes Script erstellt.

    on({id: "tuya.0.bfcf767c97aecb2b5dawpe.19"/*cur_power*/, change: "ne"}, async function (obj) {
     
     var value = obj.state.val;
      var oldValue = obj.oldState.val;
      
    getState("tuya.0.bfcf767c97aecb2b5dawpe.19", async function (err, state) {
       var value = state.val;
     log(value);
    setState('0_userdata.0.Solar_Aktuell', (value));
    
    });
    

    Leider will es nicht laufen und ich finde den Fehler nicht ...

    LatziL paul53P 2 Antworten Letzte Antwort
    0
    • T Theophilus

      Moin,
      ich messe die Leistung meiner Solaranlage mit einer WLAN-Steckdose. Über den Tuya-Adapter habe ich sie erfolgreich in den ioBroker eingebunden. Nun möchte ich die aktuelle Leistung auslesen und in einem Datenpunkt speichern. Dazu habe ich (abgeleitet von Blockly) folgendes Script erstellt.

      on({id: "tuya.0.bfcf767c97aecb2b5dawpe.19"/*cur_power*/, change: "ne"}, async function (obj) {
       
       var value = obj.state.val;
        var oldValue = obj.oldState.val;
        
      getState("tuya.0.bfcf767c97aecb2b5dawpe.19", async function (err, state) {
         var value = state.val;
       log(value);
      setState('0_userdata.0.Solar_Aktuell', (value));
      
      });
      

      Leider will es nicht laufen und ich finde den Fehler nicht ...

      LatziL Online
      LatziL Online
      Latzi
      schrieb am zuletzt editiert von
      #2

      @theophilus
      versuch´s mal damit:

      on({id: "tuya.0.bfcf767c97aecb2b5dawpe.19"/*cur_power*/, change: "any"}, async function (obj) {
       var value = obj.state.val;
       setState('0_userdata.0.Solar_Aktuell', value); 
       log(value);
      });
      
      1 Antwort Letzte Antwort
      0
      • T Offline
        T Offline
        Theophilus
        schrieb am zuletzt editiert von
        #3

        @latzi Super, das funktioniert, danke!

        1 Antwort Letzte Antwort
        0
        • T Theophilus

          Moin,
          ich messe die Leistung meiner Solaranlage mit einer WLAN-Steckdose. Über den Tuya-Adapter habe ich sie erfolgreich in den ioBroker eingebunden. Nun möchte ich die aktuelle Leistung auslesen und in einem Datenpunkt speichern. Dazu habe ich (abgeleitet von Blockly) folgendes Script erstellt.

          on({id: "tuya.0.bfcf767c97aecb2b5dawpe.19"/*cur_power*/, change: "ne"}, async function (obj) {
           
           var value = obj.state.val;
            var oldValue = obj.oldState.val;
            
          getState("tuya.0.bfcf767c97aecb2b5dawpe.19", async function (err, state) {
             var value = state.val;
           log(value);
          setState('0_userdata.0.Solar_Aktuell', (value));
          
          });
          

          Leider will es nicht laufen und ich finde den Fehler nicht ...

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

          @theophilus sagte: 0_userdata.0.Solar_Aktuell

          Damit die Objekte unter "0_userdata.0" nicht schnell unübersichtlich viele werden, empfehle ich, Ordner vom Typ "folder" oder "device" zu erstellen und erst darunter die Datenpunkte. Die Datenpunkt-ID wäre dann z.B. "0_userdata.0.Solar.Leistung".

          Blockly_temp.JPG

          Blockly liefert leider keine guten Vorgaben für strukturierten Javascript-Code, der z.B. so aussehen kann:

          const idSrc = "tuya.0.bfcf767c97aecb2b5dawpe.19";
          const idDst = "0_userdata.0.Solar.Leistung";
          
          on(idSrc, function(dp) { // triggert bei Wertänderung
              setState(idDst, dp.state.val, true); 
          });
          

          Es gibt eine Doku zu den Funktionen des Javascript-Adapters.

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

          T 1 Antwort Letzte Antwort
          0
          • paul53P paul53

            @theophilus sagte: 0_userdata.0.Solar_Aktuell

            Damit die Objekte unter "0_userdata.0" nicht schnell unübersichtlich viele werden, empfehle ich, Ordner vom Typ "folder" oder "device" zu erstellen und erst darunter die Datenpunkte. Die Datenpunkt-ID wäre dann z.B. "0_userdata.0.Solar.Leistung".

            Blockly_temp.JPG

            Blockly liefert leider keine guten Vorgaben für strukturierten Javascript-Code, der z.B. so aussehen kann:

            const idSrc = "tuya.0.bfcf767c97aecb2b5dawpe.19";
            const idDst = "0_userdata.0.Solar.Leistung";
            
            on(idSrc, function(dp) { // triggert bei Wertänderung
                setState(idDst, dp.state.val, true); 
            });
            

            Es gibt eine Doku zu den Funktionen des Javascript-Adapters.

            T Offline
            T Offline
            Theophilus
            schrieb am zuletzt editiert von
            #5

            @paul53 Super, danke für den Hinweis auf die Doku, sowas habe ich vermisst.

            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

            394

            Online

            32.9k

            Benutzer

            83.0k

            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