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. Wert aus callback an Programm übergeben

NEWS

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

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

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

Wert aus callback an Programm übergeben

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascript
4 Beiträge 3 Kommentatoren 382 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.
  • stephan1827S Offline
    stephan1827S Offline
    stephan1827
    schrieb am zuletzt editiert von
    #1

    Hallo,
    ich möchte gerne historische Daten auslesen und weiter verarbeiten. Das Auslesen klappt auch soweit aber die Funktion sendTo erwartet eine Callback Funktion mit festen Parametern. Wie bekomme ich die Daten von der Callback Funktion an das Programm übergeben? Aktuell verwende ich den Umweg über einen zusätzlichen Datenpunkt aber das führt zu diversen Problemen.

        // --------------------------------------------------------------------
        // Give 7 latest values of variables
        sendTo('history.0', 'getHistory', {id: 'javascript.0.Solar.DailyTotal', options: {end: new Date().getTime(), count: 20, aggregate: 'onchange'}}, cbSendTo1);
        function cbSendTo1(result) 
        {
            let tmpDay = '';
            let tmpSTR = '';
            let x = 0;
            for (var i = result.result.length-1; i >= 0; i--) {
                if (tmpDay != new Date(result.result[i].ts).getDate().toString())
                {
                    tmpDay = new Date(result.result[i].ts).getDate().toString();
                    tmpSTR += "data.setCell(" + x.toString() + ", 0, '" + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + "." + "');\n";
                    if(result.result[i].val == null) {tmpSTR += "data.setCell(" + x.toString() + ", 1, '0');\n";}
                    else {tmpSTR += "data.setCell(" + x.toString() + ", 1, '" + result.result[i].val + "');\n";}
                    x++;
                    if (x > 6) break;
                    console.log('Total: ' + x.toString() + ' -> ' + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + ' -> ' + result.result[i].val);
                }
            }
            setState('Solar.html1', tmpSTR);
        }
            
        tmpData += getState('Solar.html1').val;
        console.log(getState('Solar.html1').val);
    
    paul53P 1 Antwort Letzte Antwort
    0
    • stephan1827S stephan1827

      Hallo,
      ich möchte gerne historische Daten auslesen und weiter verarbeiten. Das Auslesen klappt auch soweit aber die Funktion sendTo erwartet eine Callback Funktion mit festen Parametern. Wie bekomme ich die Daten von der Callback Funktion an das Programm übergeben? Aktuell verwende ich den Umweg über einen zusätzlichen Datenpunkt aber das führt zu diversen Problemen.

          // --------------------------------------------------------------------
          // Give 7 latest values of variables
          sendTo('history.0', 'getHistory', {id: 'javascript.0.Solar.DailyTotal', options: {end: new Date().getTime(), count: 20, aggregate: 'onchange'}}, cbSendTo1);
          function cbSendTo1(result) 
          {
              let tmpDay = '';
              let tmpSTR = '';
              let x = 0;
              for (var i = result.result.length-1; i >= 0; i--) {
                  if (tmpDay != new Date(result.result[i].ts).getDate().toString())
                  {
                      tmpDay = new Date(result.result[i].ts).getDate().toString();
                      tmpSTR += "data.setCell(" + x.toString() + ", 0, '" + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + "." + "');\n";
                      if(result.result[i].val == null) {tmpSTR += "data.setCell(" + x.toString() + ", 1, '0');\n";}
                      else {tmpSTR += "data.setCell(" + x.toString() + ", 1, '" + result.result[i].val + "');\n";}
                      x++;
                      if (x > 6) break;
                      console.log('Total: ' + x.toString() + ' -> ' + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + ' -> ' + result.result[i].val);
                  }
              }
              setState('Solar.html1', tmpSTR);
          }
              
          tmpData += getState('Solar.html1').val;
          console.log(getState('Solar.html1').val);
      
      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von
      #2

      @stephan1827 sagte:

      Wie bekomme ich die Daten von der Callback Funktion an das Programm übergeben?

      Weshalb willst Du die Daten an das Hauptprogramm übergeben und nicht innerhalb der Callback-Funktion weiter verarbeiten ?
      Eine Möglichkeit, den Wert eines Datenpunktes zu verarbeiten, ist ein Trigger.

      var tmpData = '';
      on({id: 'Solar.html1'}, function(dp) {
         tmpData += dp.state.val;
         log(dp.state.val);
      });
      

      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 Antwort Letzte Antwort
      0
      • J.A.R.V.I.S.J Offline
        J.A.R.V.I.S.J Offline
        J.A.R.V.I.S.
        Developer
        schrieb am zuletzt editiert von
        #3

        @stephan1827 was genau meinst du mit übergeben?

        Du könntest daraus auch ein Promise machen und dann in einer asynchronen Funktion auf den Wert warten, dann musst du das nicht in einen State schreiben.

            // --------------------------------------------------------------------
        
            // Give 7 latest values of variables
        
        	function getHistory() {
        		return new Promise(resolve, reject) => {
        			
        			sendTo('history.0', 'getHistory', {id: 'javascript.0.Solar.DailyTotal', options: {end: new Date().getTime(), count: 20, aggregate: 'onchange'}}, result => {
        
        				let tmpDay = '';
        
        				let tmpSTR = '';
        
        				let x = 0;
        
        				for (let i = result.result.length - 1; i >= 0; i--) {
        
        					if (tmpDay != new Date(result.result[i].ts).getDate().toString()) {
        
        						tmpDay = new Date(result.result[i].ts).getDate().toString();
        
        						tmpSTR += "data.setCell(" + x.toString() + ", 0, '" + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + "." + "');\n";
        
        						if(result.result[i].val == null) {tmpSTR += "data.setCell(" + x.toString() + ", 1, '0');\n";}
        
        						else {tmpSTR += "data.setCell(" + x.toString() + ", 1, '" + result.result[i].val + "');\n";}
        
        						x++;
        
        						if (x > 6) break;
        
        						console.log('Total: ' + x.toString() + ' -> ' + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + ' -> ' + result.result[i].val);
        
        					}
        				}
        
        				resolve(tmpSTR);
        			});
        		}
        	}
        
        
        	async function tuWasMitHistory() {
        		
        		const history = await getHistory();
        		
        		tmpData += history;
        		
        		console.log(history);
        	}
        	
        	tuWasMitHistory();
        

        Oder du verarbeitest es direkt in deinem Callback.

        1 Antwort Letzte Antwort
        0
        • stephan1827S Offline
          stephan1827S Offline
          stephan1827
          schrieb am zuletzt editiert von
          #4

          Ich muss diese Funktion mehrfach aufrufen und die Daten dann weiter verarbeiten. Ich habe es jetzt so gelöst.

          Funktionsaufruf

          const history = await GetData('javascript.0.Solar.DailyTotal');
          

          Funktion

          async function GetData(strID) {
              return new Promise(function (resolve, reject) {
                      sendTo('history.0', 'getHistory', {
                              id: strID,
                              options: {
                                  end: new Date().getTime(),
                                  count: 20,
                                  aggregate: 'onchange'
                              }
                          }, (result) => {
                              if (result.error) {
                                  reject('Error: ' + result.error);
                              } else {
                                  let retData = '';
                                  let tmpDay = '';
                                  let x = 0;
                                  for (var i = result.result.length - 1; i >= 0; i--) {
                                      if (tmpDay != new Date(result.result[i].ts).getDate().toString()) {
                                          tmpDay = new Date(result.result[i].ts).getDate().toString();
                                          retData += "data.setCell(" + x.toString() + ", 0, '" + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + "." + "');\n";
                                          if (result.result[i].val == null) {
                                              retData += "data.setCell(" + x.toString() + ", 1, '0');\n";
                                          } else {
                                              retData += "data.setCell(" + x.toString() + ", 1, '" + result.result[i].val + "');\n";
                                          }
                                          x++;
                                          if (x > 6) break;
                                          console.log('Total: ' + x.toString() + ' -> ' + new Date(result.result[i].ts).getDate() + "." + new Date(result.result[i].ts).getMonth() + ' -> ' + result.result[i].val);
                                      }
                                  //console.log('1---->' + retData + '<----');
                              };
                              resolve(retData);
                          }
                      });
              });
          }
          
          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

          475

          Online

          32.8k

          Benutzer

          82.8k

          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