NEWS
daten über REST Schnittstelle lesen
-
@ben1983 sagte: Wird hier der callbackfunktion des request die foreach variable MyAssign mit übergeben?
Ich habe zwar keine Erfahrung mit der forEach-Schleife, aber meiner Meinung nach sollte es so sein, dass der Parameter MyAssign der Callback-Funktion von request() bekannt ist, da request() innerhalb der Schleifen-Funktion aufgerufen wird.
@ben1983 sagte in daten über REST Schnittstelle lesen:
Welche Werte sind in ihr verfügbar? die Zum Zeitpunkt des requests?
Ja, die zum Zeitpunkt des request-Aufrufs.
@paul53 Alle, oder nur die, welche in der foreach deklariert wurden?
das hier liefert mir im Log immer nur den Wert 6 von xy zurück.
let xy= 0; MyHistoricValue.Assign.forEach(function (MyAssign) { xy =xy+ 1; const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log(xy.toString()); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); }); -
@paul53 Alle, oder nur die, welche in der foreach deklariert wurden?
das hier liefert mir im Log immer nur den Wert 6 von xy zurück.
let xy= 0; MyHistoricValue.Assign.forEach(function (MyAssign) { xy =xy+ 1; const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log(xy.toString()); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); });@ben1983 sagte: das hier liefert mir im Log immer nur den Wert 6 von xy zurück.
Ich bevorzuge die for-Schleife:
let j = 0; for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); j++; }Log:
12:30:21.070 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 4 -
@ben1983 sagte: das hier liefert mir im Log immer nur den Wert 6 von xy zurück.
Ich bevorzuge die for-Schleife:
let j = 0; for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); j++; }Log:
12:30:21.070 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 4@paul53 ja genau so ist es ja bei mir auch.... bei dir wird "j" ja auch immer mit 4 geloggt.
Warum?
Sollte da nicht folgendes raus kommen:?1, 1 2, 2 3, 3 4, 4Denn zum Aufruf des setState (In dem Du den Callback deklarierst) ist der Wert "j" ja nicht immer 4.
Der setState entspricht ja in meinem Fall dem Request, oder?
Oder würde das bedeuten, dass nur die werte, welche innerhalb der schleife deklariert werden auch "gesichert" sind?
-
@paul53 ja genau so ist es ja bei mir auch.... bei dir wird "j" ja auch immer mit 4 geloggt.
Warum?
Sollte da nicht folgendes raus kommen:?1, 1 2, 2 3, 3 4, 4Denn zum Aufruf des setState (In dem Du den Callback deklarierst) ist der Wert "j" ja nicht immer 4.
Der setState entspricht ja in meinem Fall dem Request, oder?
Oder würde das bedeuten, dass nur die werte, welche innerhalb der schleife deklariert werden auch "gesichert" sind?
@ben1983 sagte: Der setState entspricht ja in meinem Fall dem Request, oder?
Ja, setState(id, val, ack, cb) kann eine Callback-Funktion haben.
@ben1983 sagte in daten über REST Schnittstelle lesen:
Sollte da nicht folgendes raus kommen:?
Werte von 0 bis 3, wenn der Scope der Callback-Funktion immer dem Aufruf entsprechen würde, was offensichtlich nicht der Fall ist. So tief bin ich auch noch nicht in Javascript eingetaucht, um darauf eine Antwort geben zu können (lerne Javascript erst seit der Beschäftigung mit ioBroker).
-
@ben1983 sagte: das hier liefert mir im Log immer nur den Wert 6 von xy zurück.
Ich bevorzuge die for-Schleife:
let j = 0; for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); j++; }Log:
12:30:21.070 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 4 12:30:21.071 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 4@paul53 Scheint so zu sein, dass nur innerhalb der Schleife die Werte dem Callback übergeben werden.
so geht es:
let xy= 0; MyHistoricValue.Assign.forEach(function (MyAssign) { xy =xy+ 1; let xyz = xy; log("Direkt: " + xyz.toString()); const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log("In Callback" + xyz.toString()); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); });und deshalb auch mit meinen Variablen MyAssign.InternalId, da diese ja teil der Schleife ist.
Für MyDevice würde ich mir wahrscheinlich eine Zusatz variable erstellen müssen.Oder kann man dem callback auch noch zusätzliche Variablen übergeben?
-
@paul53 Scheint so zu sein, dass nur innerhalb der Schleife die Werte dem Callback übergeben werden.
so geht es:
let xy= 0; MyHistoricValue.Assign.forEach(function (MyAssign) { xy =xy+ 1; let xyz = xy; log("Direkt: " + xyz.toString()); const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log("In Callback" + xyz.toString()); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); });und deshalb auch mit meinen Variablen MyAssign.InternalId, da diese ja teil der Schleife ist.
Für MyDevice würde ich mir wahrscheinlich eine Zusatz variable erstellen müssen.Oder kann man dem callback auch noch zusätzliche Variablen übergeben?
@ben1983 sagte:
let xy= 0; MyHistoricValue.Assign.forEach(function (MyAssign) { xy =xy+ 1; let xyz = xy;Hast Du es mal so versucht?
MyHistoricValue.Assign.forEach(function (MyAssign, xy) {xy sollte dabei der Index sein (siehe hier).
-
@ben1983 sagte:
let xy= 0; MyHistoricValue.Assign.forEach(function (MyAssign) { xy =xy+ 1; let xyz = xy;Hast Du es mal so versucht?
MyHistoricValue.Assign.forEach(function (MyAssign, xy) {xy sollte dabei der Index sein (siehe hier).
@paul53 komischerweise macht er es beidemDevice.Id richtig und nimmt den wert zum Zeitpunkt des request Aufrufes:
MyHistoricValue.Assign.forEach(function (MyAssign) { const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log(MyDevice.Id); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } });Mit deiner Variante:
let xy = 0; MyHistoricValue.Assign.forEach(function (MyAssign,xy) { xy = xy+ 1; const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log(xy.toString()); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); });funktioniert es auch.
Aber warum muss ich normale Parameter übergeben und parameter einer übergeordneten foreach nicht?
-
@paul53 komischerweise macht er es beidemDevice.Id richtig und nimmt den wert zum Zeitpunkt des request Aufrufes:
MyHistoricValue.Assign.forEach(function (MyAssign) { const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log(MyDevice.Id); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } });Mit deiner Variante:
let xy = 0; MyHistoricValue.Assign.forEach(function (MyAssign,xy) { xy = xy+ 1; const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { if(error) { log(error, 'warn'); } else { log(xy.toString()); log(result); let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); });funktioniert es auch.
Aber warum muss ich normale Parameter übergeben und parameter einer übergeordneten foreach nicht?
-
@paul53 ja tut es, aber jetzt stellt sich mir wirklich die Frage, welche Variablen habe ich nun dort zur Verfügung und welche nicht?
Nur die, die ich in der letzten Foreach erstelle?
-
@ben1983 sagte: Nur die, die ich in der letzten Foreach erstelle?
Das sieht so aus. Callback-Funktionen innerhalb von Schleifen haben eben ihre Besonderheiten, denn schließlich müssen sie dynamisch (zur Laufzeit) erzeugt werden.
-
@paul53 OK, aber offensichtlich enthält der callback nicht die werte beim Aufruf.
Zumindest nicht die normalen Variablen. -
@ben1983 sagte: Zumindest nicht die normalen Variablen.
Ja, offenbar nur die lokalen Variablen, deren Gültigkeit auf die Schleife begrenzt ist.
@paul53 Ja, aber auch hier wieder Ausnahmen, denn die Variable "MyDevice.Id" wurde auch in der letzten Schleife richtig erkannt.
Lege ich in der ersten schleife eine lokale variable an, dann wieder nicht.kann man eigenlich die callbackfunktion von dem request noch erweitern?
also Parameter übergeben? -
@paul53 Ja, aber auch hier wieder Ausnahmen, denn die Variable "MyDevice.Id" wurde auch in der letzten Schleife richtig erkannt.
Lege ich in der ersten schleife eine lokale variable an, dann wieder nicht.kann man eigenlich die callbackfunktion von dem request noch erweitern?
also Parameter übergeben? -
@paul53 Ja, aber auch hier wieder Ausnahmen, denn die Variable "MyDevice.Id" wurde auch in der letzten Schleife richtig erkannt.
Lege ich in der ersten schleife eine lokale variable an, dann wieder nicht.kann man eigenlich die callbackfunktion von dem request noch erweitern?
also Parameter übergeben?@ben1983 sagte: die Variable "MyDevice.Id" wurde auch in der letzten Schleife richtig erkannt.
Auf diese wird nicht in der Callback-Funktion zugegriffen. Die Einschränkung auf lokale Schleifen-Variablen bezieht sich nur auf Variablen, deren Wert in der Schleife verändert wird und auf die in der Callback-Funktion zugegriffen wird.
-
@ben1983 sagte: die Variable "MyDevice.Id" wurde auch in der letzten Schleife richtig erkannt.
Auf diese wird nicht in der Callback-Funktion zugegriffen. Die Einschränkung auf lokale Schleifen-Variablen bezieht sich nur auf Variablen, deren Wert in der Schleife verändert wird und auf die in der Callback-Funktion zugegriffen wird.
-
@paul53 OK, ich hatte sie aber einmal zum test einfach dort geloggt und das hatte funktioniert.
-
@ben1983 sagte: dort geloggt und das hatte funktioniert.
Innerhalb der Schleife ist "MyDevice.Id" eine Konstante.
-
@ben1983 sagte: Wird doch auch durchlaufen in der obersten schleife.
In der äußeren Schleife ist es eine lokale Schleifen-Variable. In der inneren Schleife ist es ein konstanter Wert.
Test:for(let j = 0; j < 3; j++) { for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); } }Log:
15:50:17.919 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 0 15:50:17.920 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 0 15:50:17.920 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 0 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 0 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 1 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 1 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 1 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 1 15:50:17.924 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 2 15:50:17.927 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 2 15:50:17.927 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 2 15:50:17.928 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 2Gegentest:
let j; for(j = 0; j < 3; j++) { for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); } }15:52:42.649 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 3 15:52:42.649 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 3 15:52:42.649 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 3 15:52:42.655 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 3 -
@ben1983 sagte: Wird doch auch durchlaufen in der obersten schleife.
In der äußeren Schleife ist es eine lokale Schleifen-Variable. In der inneren Schleife ist es ein konstanter Wert.
Test:for(let j = 0; j < 3; j++) { for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); } }Log:
15:50:17.919 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 0 15:50:17.920 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 0 15:50:17.920 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 0 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 0 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 1 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 1 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 1 15:50:17.921 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 1 15:50:17.924 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 2 15:50:17.927 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 2 15:50:17.927 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 2 15:50:17.928 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 2Gegentest:
let j; for(j = 0; j < 3; j++) { for(let i = 0; i < 4; i++) { setState('0_userdata.0.Test.neueZahl'/*neueZahl*/, j , true, function() { log(i + ', ' + j); }); } }15:52:42.649 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 3 15:52:42.649 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 3 15:52:42.649 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 0, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 1, 3 15:52:42.650 info javascript.0 (1986) script.js.common.Neuer_Test: 2, 3 15:52:42.655 info javascript.0 (1986) script.js.common.Neuer_Test: 3, 3@paul53 Das ist mir schon klar... fürchte wir reden aneinander vorbei:
Mir geht es um die Werte, wie sie später im Callback zur Verfügung stehen.Habe gerade nochmal einen Test gemacht:
let x = 0; MyDevice.HistoricValue.forEach(function (MyHistoricValue) { let y = 0; MyHistoricValue.Assign.forEach(function (MyAssign) { x = x + 1; y = y + 1; let ax= x; let ay= y; const Url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/' + MyDevice.Id + '/hist/energy/' + MyHistoricValue.Value + '/' + MyAssign.Type + '/.json?' + MyAssign.Time; request(Url, function(error, response, result) { log("X: " + ax.toString() + "Y: " + ay.toString()); if(error) { log(error, 'warn'); } else { let value = JSON.parse(result).energy if(value != NaN &&value != "NaN") { setState(MyAssign.InternalId,value); } else { log(result); log("Es gab einen fehlerhaften Eintrag in der Response von GridVis: " + MyAssign.InternalId); } } }); x = x + 1; y = y + 1; ax = x; ay =y; }); });offensichtlich stehen für den Callback NICHT die Werte zum Zeitpunkt des Requests zur Verfügung, sondern die Werte am Ende des Schleifendurchlaufs, denn ich bekam hier diesen Log:

Also immer 2er Schritte. (Addition vor und nachdem Request.
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