NEWS
Вопросы по написанию скриптов
-
Скобки надо поставить при вызове функции. `
Спасибо, а как подписаться на открытие конкретной страницы? -
Данный код при разницы времени больше 5 минут между текущим временем и временем обновления данных, вешает сервер, и через полминуты сервер остается с 3% оперативки, далее не отвечает вообще.
Код не полный, ниже еще функция sendMessage();, но она точно не влияет. Все работало, пока цикл while не написал.
Моя логика какая- считываем данные, если данные старее чем 5 минут, то обновляем запрос setTimeout (600, pusk()); После запроса считываем опять время полученное от сервера Apple, через драйвер find-my-iphone.
! on({id: 'javascript.0.find_my_iphone.irina', change: 'any'}, function (obj) {
! var date = new Date();//
! var time = date.getTime(); // время в миллисикунндах от 1970 года
! var timeStamp = getState("find-my-iphone.0.iPhone_Ira.timeStamp").val; // время последнего обновления данных в миллисикунндах от 1970 года
! var diftime = time - timeStamp;
! while (diftime > 300000) { //1000 - секунда 60000 - минута 1800000 - 30 минут - стоит 5 минут = 300000
! timeStamp = getState("find-my-iphone.0.iPhone_Ira.timeStamp").val;
! diftime = time - timeStamp;
! log ('while '+diftime);
! setTimeout (600, pusk()); //именно ира
! }
! if (obj.newState.val === true || obj.newState.val === 'true'){
! setState('javascript.0.find_my_iphone.irina', 'false');
! setState("find-my-iphone.0.refresh", true);
! sendMessage();
! }
! });
! function pusk() {
! setState("find-my-iphone.0.iPhone_Ira.refresh", true); //именно ира
! } -
Скобки надо поставить при вызове функции.
Спасибо, а как подписаться на открытие конкретной страницы?function myfunction() { // } function start() { on({id: 'vis.0.control.command', change: 'any'}, function (obj) { if (obj.state.val == 'changedView' ) { if (getState('vis.0.control.data').val === 'страница') myfunction(); } }); } start(); -
Столкнулся с проблемой. При попытке использовать getState, драйвер выдаёт ошибку.
Пробую как в примерах
!

При этом драйвер начинает ругаться!

Пробую с колбеком,и в нём менять значение
!

Но если добавить вывод в лог, в колбеке, то работает
!

Если сделать так
t = setInterval(function () { console.log(getState('javascript.0.temp', function (err, state){}).val); }, 1000);То в лог сыпятся ошибки
!

Где допускаю ошибку? Гугл толком не помог.
Заранее спасибо
-
Столкнулся с проблемой. При попытке использовать getState, драйвер выдаёт ошибку.
Пробую как в примерах
Где допускаю ошибку? Гугл толком не помог.
Заранее спасибо `
А почему не так?
setInterval(function () { console.log(getState('javascript.0.temp').val); }, 1000);Хотя и так работает.
var t; t = setInterval(function() { console.log(getState("mqtt.0.SpectreKr.podval.signaling").val) }, 18000);Может интервал сильно маленький?
-
Попробовал ваш вариант
Независимо от интервала, в логе сообщение
14:55:00.860 [error] javascript.0 script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){});И драйвер выдаёт в лог целый ворох ошибок, так же как и раньше
Server-Izzm 2017-02-16 14:55:00.894 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 14:55:00.862 info terminating javascript.0 2017-02-16 14:55:00.854 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 14:55:00.854 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 14:55:00.854 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 14:55:00.854 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 14:55:00.854 error at Object. (script.js.Скрипт1:2:46) javascript.0 2017-02-16 14:55:00.854 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.848 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.837 error script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){}); -
Попробовал ваш вариант
Независимо от интервала, в логе сообщение
14:55:00.860 [error] javascript.0 script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){});И драйвер выдаёт в лог целый ворох ошибок, так же как и раньше
Server-Izzm 2017-02-16 14:55:00.894 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 14:55:00.862 info terminating javascript.0 2017-02-16 14:55:00.854 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 14:55:00.854 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 14:55:00.854 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 14:55:00.854 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 14:55:00.854 error at Object. (script.js.Скрипт1:2:46) javascript.0 2017-02-16 14:55:00.854 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.848 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.837 error script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){}); ```` `var t; t = setInterval(function() { var v = getState('javascript.0.temp').val; log(v); }, 2000); -
Читаю другое свойство, которое точно существует
!

Код взял из сообщения instalator.var t; t = setInterval(function() { var v = getState('javascript.0.RealTemp.temp').val; log(v); }, 2000);Вывод в лог в редакторе скриптов
19:30:57.235 [info] javascript.0 Start javascript script.js.script 19:30:57.235 [info] javascript.0 script.js.script: setInterval(ms=2000) 19:30:57.236 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 19:30:59.255 [error] javascript.0 script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){});В глобальном логе
Server-Izzm 2017-02-16 19:30:59.273 info Restart adapter system.adapter.javascript.0 because enabled host.Server-Izzm 2017-02-16 19:30:59.273 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 19:30:59.257 info terminating javascript.0 2017-02-16 19:30:59.248 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 19:30:59.248 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 19:30:59.248 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 19:30:59.248 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 19:30:59.248 error at Object. (script.js.script:4:67) javascript.0 2017-02-16 19:30:59.248 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.242 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.233 error script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){}); -
Читаю другое свойство, которое точно существует
! Gate8.PNG
Код взял из сообщения instalator.var t; t = setInterval(function() { var v = getState('javascript.0.RealTemp.temp').val; log(v); }, 2000);Вывод в лог в редакторе скриптов
19:30:57.235 [info] javascript.0 Start javascript script.js.script 19:30:57.235 [info] javascript.0 script.js.script: setInterval(ms=2000) 19:30:57.236 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 19:30:59.255 [error] javascript.0 script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){});В глобальном логе
Server-Izzm 2017-02-16 19:30:59.273 info Restart adapter system.adapter.javascript.0 because enabled host.Server-Izzm 2017-02-16 19:30:59.273 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 19:30:59.257 info terminating javascript.0 2017-02-16 19:30:59.248 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 19:30:59.248 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 19:30:59.248 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 19:30:59.248 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 19:30:59.248 error at Object. (script.js.script:4:67) javascript.0 2017-02-16 19:30:59.248 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.242 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.233 error script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){}); ```` `А так?
var t; t = setInterval(function() { getState("javascript.0.RealTemp.temp", function (err, state){ log(JSON.stringify(state)); }); }, 2000); -
Вывод в лог. У state в val есть нужное значение.
19:56:08.143 [info] javascript.0 Start javascript script.js.script 19:56:08.144 [info] javascript.0 script.js.script: setInterval(ms=2000) 19:56:08.144 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 19:56:10.147 [info] javascript.0 script.js.script: {"val":24.5,"ack":true,"ts":1487264169069,"q":0,"from":"system.adapter.javascript.0","lc":1487263250738}И так работает
var t; var vv; t = setInterval(function() { getState("javascript.0.RealTemp.temp", function (err, state){ log(JSON.stringify(state.val)); vv=state.val; }); log(vv); }, 2000);20:05:09.423 [info] javascript.0 Start javascript script.js.script 20:05:09.424 [info] javascript.0 script.js.script: setInterval(ms=2000) 20:05:09.424 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 20:05:11.424 [info] javascript.0 script.js.script: undefined 20:05:11.426 [info] javascript.0 script.js.script: 24.5 20:05:13.429 [info] javascript.0 script.js.script: 24.5 20:05:13.432 [info] javascript.0 script.js.script: 24.5 -
Пытаюсь из строки выбрать IP адрес, сделал регулярное выражение и парсю строку.
!
var reg_ip = new RegExp ('(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-4])'); var ip; var str = "first L2TP UDP packet received from 217.15.203.52"; //var str = "error: WARNING: cannot find message with id = 27946818"; ip = reg_ip.exec(str); if(ip){ log("IP: " + ip[0]); } !
Из первой строки выводит только первые две декты IP, а из второй все число, хотя на IP оно и близко не похоже. -
Все сдаюсь, "обожаю" асинхронность JS. Есть цикл, надо сообщения выводит с задежркой, чтоб телеграмм не заблочил.
! ````
for (var a in res.result) {
if(res.result[a].work.indexOf('/1') > 0){
str = res.result[a].work.replace(new RegExp('/1','g'),' очень низкий');}else if(res.result[a].work.indexOf('/2') > 0){ str = res.result[a].work.replace(new RegExp('/2','g'),' _низкий_'); }else if(res.result[a].work.indexOf('/3') > 0){ str = res.result[a].work.replace(new RegExp('/3','g'),' _средний_'); }else if(res.result[a].work.indexOf('/4') > 0){ str = res.result[a].work.replace(new RegExp('/4','g'),' _высокий_'); }else if(res.result[a].work.indexOf('/5') > 0){ str = res.result[a].work.replace(new RegExp('/5','g'),' _очень высокий_'); } sendTo('telegram.0', {user: us, text: '*' + res.result[a].name + '*' + '\n' + str, parse_mode: 'Markdown'}); } -
Пытаюсь проделать следующий финт:
На закладке объектов создать в корне папку и наполнить ее разными объектами.
Например создать папку Flags и там различные объекты к которым могу обращаться из различных инстанций Javascript.0 или Javascript.1
Зачем это. Ну просто обособить свои объекты. Насоздавал например объектов в Javascript.1, а затем нечаяно грохнул его и все потерялось. А так все на месте и к ним можно обратиться из Javascript.0. И соответственно скрипты рассчитанные на одновременную работу с данными могут находится в разных инстанциях.
Но почему то не могу создать первоначальную папку в корне, куда потом прятать все содержимое. Позволяет только создать состояние|канал|устройство. Но если создавать любой из этих объектов, то все дочерние визуально лежат рядом.
Чего я неправильно делаю

-
Проще создать нужные объекты скриптом
CreateState('папка.объект', " ");
Пишу с пульта….
-
@kID:Пытаюсь проделать следующий финт:
На закладке объектов создать в корне папку и наполнить ее разными объектами.
Например создать папку Flags и там различные объекты к которым могу обращаться из различных инстанций Javascript.0 или Javascript.1
Зачем это. Ну просто обособить свои объекты. Насоздавал например объектов в Javascript.1, а затем нечаяно грохнул его и все потерялось. А так все на месте и к ним можно обратиться из Javascript.0. И соответственно скрипты рассчитанные на одновременную работу с данными могут находится в разных инстанциях.
Но почему то не могу создать первоначальную папку в корне, куда потом прятать все содержимое. Позволяет только создать состояние|канал|устройство. Но если создавать любой из этих объектов, то все дочерние визуально лежат рядом.
Чего я неправильно делаю Скриншот 2017-02-25 21.53.53.png `
Создай сразу всю ветку. Например kitchen.flag
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