NEWS
Hilfe beim skripten
-
danke für deine Hilfe
-
Hey again
darf ich Euch Profis nochmals (mehrmals vermutlich) anzapfen?
Wie gebe ich mit log eine Variable aus?
log("db", "info"); geht nicht
log(db, "info"); geht nicht
soweit ich gesehen habe gibt man Variablen in javascript auch nicht mit $db oder so an.. also wie bitte?
-
Hey again
darf ich Euch Profis nochmals (mehrmals vermutlich) anzapfen?
Wie gebe ich mit log eine Variable aus?
log("db", "info"); geht nicht
log(db, "info"); geht nicht
soweit ich gesehen habe gibt man Variablen in javascript auch nicht mit $db oder so an.. also wie bitte? `
log(db, "info");sollte gehen wie heisst deine Variable?
-
meine Var heisst "db_tageszeit"
das log gibt mir folgendes aus mit: log(db_tageszeit, "info");
javascript.0 2016-02-25 19:26:32 error javascript.0 script.js.Regenvariable_setzen_und_Meldung: script.js.Regenvariable_setzen_und_Meldung:6 log(db_tageszeit, "info"); ^ ReferenceError: db_tageszeit is not defined at regen
-
so sieht der Scriptteil aus:
function regen(dp_regensensor) { var dp_tageszeit = getState("hm-rega.0.23707"/*Tageszeit*/); log(db_tageszeit, "info");
-
so sieht der Scriptteil aus:
function regen(dp_regensensor) { var dp_tageszeit = getState("hm-rega.0.23707"/*Tageszeit*/); log(db_tageszeit, "info"); ```` `
Hi,
du hast .val vergessen.
var dp_tageszeit = getState("hm-rega.0.23707"/*Tageszeit*/).val;
Bin aber Rookie und habe keine Ahnung…
1146_easymeter.jpg -
nope, das war's auch nicht
-
Schreib mal was anderes in die Variable = "Hallo Welt"
-
mh.. "Hello World" wird im log ausgegeben
-
ok.. ich brings nicht hin, dass die CCU Variable ausgegeben wird
was anderes, wie funktioniert das mit dem on({"hm-rpc.0.JEQ0156528.3.STATE", "change": "ne"}, function()); ?
egal ob ich da "ne", "eq" oder was anderes stehen habe.. er führt die Funktion trotzdem aus
-
Auf was willst du denn reagieren?
on({"hm-rpc.0.JEQ0156528.3.STATE", "change": "ne"}, function());
hier könnte id fehlen!
on({id: "hm-rpc.0.JEQ0156528.3.STATE", "change": "ne"}, function());
-
habe ich auch schon probiert, in Anführungszeichen und ohne… egal ob dann "eq" oder "ne" steht... script wird ausgeführt
mit dem xxx.STATE frage ich ein Schließerkontaktinterface ab, nur zur Info
-
var dp_tageszeit = getState("hm-rega.0.23707"/Tageszeit/);
log(db_tageszeit, "info"); `
Wenn die Variable _dptageszeit deklariert wird, kann der log mit _dbtageszeit nicht funktionieren. Besser:log(dp_tageszeit.val, "info");
3435_screenshot__67_.png
3435_screenshot__66_.png
3435_screenshot__65_.png
3435_screenshot__68_.png
3435_screenshot__69_.png
3435_screenshot__70_.png -
var dp_tageszeit = getState("hm-rega.0.23707"/*Tageszeit*/); // var tageszeit_db = "Hello World"; log(db_tageszeit.val, "info");
gibt mir folgendes im log:
javascript.0 2016-02-25 21:01:17 error javascript.0 script.js.Regenvariable_setzen_und_Meldung: script.js.Regenvariable_setzen_und_Meldung:7 log(db_tageszeit.val, 'info'); ^ ReferenceError: db_tageszeit is not defined at regen (script.js.Regenvariable_setzen_und_Meldung:7:9) at script.js.Regenvariable_setzen_und_Meldung:38:102
wobei hm-rega.0.23707 eine ccu Variable mit true / false ist
-
Code: Alles auswählen
var dp_tageszeit = getState("hm-rega.0.23707"/Tageszeit/);
// var tageszeit_db = "Hello World";
log(db_tageszeit.val, "info"); `
In meinem Post habe ich das harte "p" und das weiche "b" extra fett markiert. Trotzdem übersehen ? -
lol.. ups
314_unbenannt.jpg -
und siehe da.. es funktioniert… hätte früher eine Pause machen sollen und Morgen nochmals schauen
Danke für die Hilfe
-
Hey,
ich wieder …
mit diesem Script will ich mir die Außentemperatur bei jedem Update auf Telegram schicken lassen.
Er macht das auch beim händischen starten, oder abspeichern des Scripts, allerdings nicht von alleine.
Beim händischen starten läuft alles, wenn die Temperatur upgedatet wird. Danach kommt im Log:````
javascript.0 2016-02-26 13:23:01 warn javascript.0 State "undefined" not foundhier das Script, was ist falsch?
function temperatur(dp_temp)
{
setState("telegram.0.communicate.response", "Es hat Draußen "+dp_temp.val+" °C");
log("Temperatur: "+dp_temp.val+" °C", "info");
}on({id: "hm-rpc.0.KEQ0174268.1.TEMPERATURE", change: "any"}, temperatur(getState("hm-rpc.0.KEQ0174268.1.TEMPERATURE")));
[3822_bildschirmfoto_2019-02-03_um_18.05.53.png](/assets/uploads/files/3822_bildschirmfoto_2019-02-03_um_18.05.53.png)
-
on(…) übergibt immer das Datenpunkt-Objekt. Dagegen muss man sich bei Scriptstart das State-Objekt mit getState() holen, will man innerhalb der Funktion auf das Objekt zugreifen:
function temperatur(dp_temp) { setState("telegram.0.communicate.response", "Es hat Draußen "+dp_temp.val+" °C"); log("Temperatur: "+dp_temp.val+" °C", "info"); } on({id: "hm-rpc.0.KEQ0174268.1.TEMPERATURE", change: "any"}, function(dp) { temperatur(dp.state); }); // Soll die Funktion auch bei Scriptstart ausgeführt werden, dann temperatur(getState("hm-rpc.0.KEQ0174268.1.TEMPERATURE"));
-
Danke probiere ich bald aus
Gesendet von meinem HUAWEI CRR-L09 mit Tapatalk