NEWS
[gelöst] on-funktionen generieren aus einem object
-
das mit den "echten" Alias ist mir bewusst.
Zwei Gründe:
ich wollte möglichst alles selbst erstellen um meine Programmierfähigkeiten weiter auszubauen. Bin nicht grad Profi... Daher zu meiner eigenen Übung.
Zweitens: Ein Alias würde sofort den Original-State schalten. Das will ich aber ja nicht, ich will den über die funktion "ansteuern" schalten, um die Überwachung mit drin zu haben.Ich hab das mal geloggt.
Egal welches Gerät ich schalte, die on-funktion wird getriggert.
Aber wenn ich mir noch vor der if-Bedingung ein log reinsetze, das mir den trigger ausgibt, kommt immer aussen_heckenlicht_State.var flags = {}; for (var key in homeKitobjectAlias) { var origID = eval(homeKitobjectAlias[key].orig); var aliasID = homeKitobjectAlias[key].alias; var flagID = homeKitobjectAlias[key].flag; on({id: aliasID, change: "ne"}, function (obj) { console.log("alias: " + aliasID) console.log("flagAlias: " + flagName) if (flags[flagName]) { flags[flagName] = false; } else { flags[flagName] = true; ansteuern(origID, obj.state.val, obj.oldState.val, aliasID); } }); on({id: origID, change: "ne", ack: true}, function (obj) { console.log("origID: " + origID) console.log("flagOrig: " + flagName) if (flags[flagName]) { flags[flagName] = false; } else { flags[flagName] = true; setState(aliasID, obj.state.val, true); } }); }
Danke für die schnelle Antwort!
-
@benni27 sagte in on-funktionen generieren aus einem object:
Ich hab das mal geloggt.
Egal welches Gerät ich schalte, die on-funktion wird getriggert.Interessant wäre hier in Zeile 8 zu loggen, welche Trigger überhaupt angelegt werden.
Also welche Werte in den 3 Variablen stehen.@benni27 sagte in on-funktionen generieren aus einem object:
Ein Alias würde sofort den Original-State schalten
Das schon - er würde es zumindest versuchen.
Also könnte man an jeden Alias einen Trigger hängen, der nach einem Timeout prüft, ob das Ack-Flag (des Ziels) sitzt.Apropos Timeout: Bevor ein Timeout gestartet wird, löscht man denselben zuerst mal.
Hintergrund: Wenn Du z.B. innerhalb von 3 Sekunden eine Lampe x-mal schaltest, werden auch x Timeouts gestartet.
Wirklich "wirken" soll aber immer nur einer (der letzte).@benni27 sagte in on-funktionen generieren aus einem object:
ich wollte möglichst alles selbst erstellen um meine Programmierfähigkeiten weiter auszubauen. Bin nicht grad Profi... Daher zu meiner eigenen Übung.
Ich auch nicht - jedenfalls nicht mit JavaScript
-
@codierknecht
zeile 8 hab ich auch mal geloggt. es werden alle trigger sauber angelegt.
aber auffällig ist, dass der letzte angelegte aussen_heckenlicht_state ist.ich probier mal weiter. evtl. hab ich einen Ansatz.
Danke schonmal!
und danke für den Tipp mit Timer. Werd ich noch nachziehen, macht Sinn
-
@benni27 sagte in on-funktionen generieren aus einem object:
Wenn ich mir den homeKitaliasObject[key].orig per console ausgeben lasse, steht auch immer nur aussen_Heckenlicht_STATE drin
und das ist wahrscheinlich der letzte in der Liste?
Das hat etwas mit Scope zu tun.
In Zeile 48 bis 50 holst du dir immer den aktuellen Wert.
Der reicht auch für das definieren von ON aus.
Wenn dann der trigger aktiviert wird, dann steht bspw in aliasID
immer noch der Wert drin, den aliasID als letztes in der Schleife abgespeichert wurde.Das beste ist, du erzeugst dir eine Datenstruktur (Array of Objects), welche du diese ganzen Informationen speicherst und dann bei Aufruf des Triggers dir dann aus dem Array wieder holst. Der eindeutige ID des Arrays wäre dann etwas, was du aus obj holst (bspw der getriggerte Datenpunkt)
-
@oliverio
richtig, das ist der letzte in der Liste.vielen Dank für die Hinweise. Ich werde mich morgen nochmal dransetzen.
hab jetzt spätschicht.. -
@oliverio
so ich hab jetzt mal nochmal bisschen rumprobiert.
ich komme nicht ganz drauf wie du das meinst, kannst du mir evtl ein Beispiel geben?ich habe so viel verschiedenes jetzt probiert..
ich habe dann auch versucht, das nicht über eine for schleife zu lösen, sondern eine einzige On-Funktion, die als trigger das gesamte objekt homeKitobjectAlias. also ungefähr in dem stil:on(homeKitobjectAlias, function(obj){ var origID = obj.id ... }
hat aber auch nicht funktioniert. je nachdem wie ich meine variablen in der funktion deklariere, kommt entweder ein schwall an undefined meldungen im Log, oder es kommen alle states die ich in der gesamten objectliste stehen hab. Unabhängig von dem Object homeKitobjectAlias. Und dementsprechend auch ein ordentlicher Überlauf im Log..
hab aber auch viel anderes probiert. Könntest du mir ein kurzes Beispiel geben, dass ich verstehe wie du das meinst konkret?
Danke schonmal
-
@benni27 sagte in on-funktionen generieren aus einem object:
@oliverio
so ich hab jetzt mal nochmal bisschen rumprobiert.
ich komme nicht ganz drauf wie du das meinst, kannst du mir evtl ein Beispiel geben?wenn ich das richtig erinnere solltest du in deiner For-Schleife die lokalen Variablen nicht via "var" sondern via "const" definieren. Dann müsste es gehen.
Genau erklären kann ich es heute Abend aber nicht mehr.
for (var key in homeKitobjectAlias) { const origID = eval(homeKitobjectAlias[key].orig); const aliasID = homeKitobjectAlias[key].alias; const flagID = homeKitobjectAlias[key].flag; on({id: aliasID, change: "ne"}, function (obj) {
-
@asgothian
Woow! es funktioniert!
Super danke!hab jetzt den Code genau so wie anfangs gepostet, nur mit const anstatt var. jetzt geht alles.
an was für kleinigkeiten das immer hängen kann ey.. danke!
liebe grüße, Benni
-
@benni27 sagte in on-funktionen generieren aus einem object:
jetzt geht alles.
Fein. Inzwischen habe ich auch meine Notizen wieder gefunden warum das so ist:
- die mit "var" deklarierten Variablen sind auch ausserhalb des Scope (der For Schleife) bekannt, und damit global. In das "on" wird anscheinend ein Verweis auf diese Variable eingetragen. Am Ende der Schleife steht da genau die ID des letzten Laufs drin - alle Trigger gehen also auf die ID.
- durch die Definition mit "const" (sollte auch bei "let" funktionieren) ist der Scope begrenzt auf die for-schleife, weswegen anscheinend der Wert und nicht die Referenzen weiter gegeben werden.
-
ja ist richtig, global ist allerdings das falsche Wort.
Die geschweiften Klammern sind immer so ein Indikator dafür,
das ein neue Scope für javascript eröffnet wird.
Variablen die ausserhalb (scope1) des aktuellen Scopes (scope2) deklariert worden sind, sind auch innerhalb des scopes sichtbar.
bei const, kann man das nur einmal zuweisen und passt hier für das Beispiel. Wenn man noch Berechnungen für diese Variable durchführen möchte, könnte man auch noch let verwenden.Der Unterschied zu var ist hier beschrieben var ist function-scoped und const/let ist block-scoped.
bei var kommt dann noch das sogenannte hoisting zum tragen.
egal wo es innerhalb einer funktion deklariert wird, intern wird die deklaration immer am Anfang der Funktion gemacht. Daher am besten es auch dort notierenfor (var key in homeKitobjectAlias) { //scope 1 const origID = eval(homeKitobjectAlias[key].orig); const aliasID = homeKitobjectAlias[key].alias; const flagID = homeKitobjectAlias[key].flag; on({id: aliasID, change: "ne"}, function (obj) { //scope 2 }
-
@oliverio bzw. am besten "var" ganz vermeiden, das führt nur zur Unklarheiten.
-
Vielen Dank für eure Hilfe. Hat mir sehr weitergeholfen. Danke auch für die Erklärungen! Werde in Zukunft primär let/const verwenden!
Ich weiss leider nicht wo ich die Frage als gelöst markieren kann? Ist mein erster Forenbeitrag..
-
@benni27 sagte in on-funktionen generieren aus einem object:
Ich weiss leider nicht wo ich die Frage als gelöst markieren kann? Ist mein erster Forenbeitrag..
Bearbeite Deinen Eingangspost und setze ein "[gelöst] - " vor den Titel.