Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. Скрипты
    5. ioBroker скрипты
    6. Вопросы по написанию скриптов

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    Вопросы по написанию скриптов

    This topic has been deleted. Only users with topic management privileges can see it.
    • A
      andrey99986 last edited by

      @MSapogov:

      И на последок, в какое место вставить cron для строки setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %"); чтобы она выполнялась каждые 2 секунды?

      Скрипт on({id: 'mqtt.0.beeiot.Bee-RGB.gpioint1', change: 'any'}, function (obj) {

      setState("squeezebox.0.Children.volume", getState("squeezebox.0.Children.volume").val + 1);

      }); - работает безупречно!!! `

      А зачем? согласно документации на https://github.com/ioBroker/ioBroker.javascript

      Функция "on" запускает "слушатель" на изменение или обновления состояния.

      Соответственно если запустить в "Скриптах" 1 раз - будет слушать и реагировать всегда.

      1 Reply Last reply Reply Quote 0
      • S
        spectrekr last edited by

        @andrey99986:

        А зачем? согласно документации на https://github.com/ioBroker/ioBroker.javascript

        Функция "on" запускает "слушатель" на изменение или обновления состояния.

        Соответственно если запустить в "Скриптах" 1 раз - будет слушать и реагировать всегда. `

        Согласно ТЗ человека.
        @MSapogov:

        А так -же при появлении события mqtt.0.beeiot.Bee-RGB.gpioint1 неважно какое, главное новое событие - изменить значение squeezebox.0.Children.volume на +1 `

        @MSapogov:

        И на последок, в какое место вставить cron для строки setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %"); чтобы она выполнялась каждые 2 секунды? `

        schedule("*/2 * * * * *", function () {

        setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %");

        });

        1 Reply Last reply Reply Quote 0
        • A
          andrey99986 last edited by

          Проблема - если в скрипте ошибка, драйвер Javascript начинает бесконечно перезапускаться, в лог пишет одно и то же:

          host-home	2016-09-14 12:36:08.572	info	Restart adapter system.adapter.javascript.0 because enabled
          host-home	2016-09-14 12:36:08.571	error	instance system.adapter.javascript.0 terminated with code 0 (OK)
          javascript-0	2016-09-14 12:36:08.563	info	terminating
          Error:	2016-09-14 12:36:08.559	error	at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:78:26)
          Error:	2016-09-14 12:36:08.559	error	at errnoException (dns.js:27:10)
          Error:	2016-09-14 12:36:08.559	error	getaddrinfo ENOTFOUND 192.168.2.10:8088 192.168.2.10:8088:80
          

          при этом зайти в "Скрипты" и исправить её невозможно - страница "Скрипты" не загружается.

          Что в таких случаях делать?

          1 Reply Last reply Reply Quote 0
          • E
            electric last edited by

            @andrey99986:

            Проблема - если в скрипте ошибка, драйвер Javascript начинает бесконечно перезапускаться

            при этом зайти в "Скрипты" и исправить её невозможно - страница "Скрипты" не загружается.

            Что в таких случаях делать? `
            Можно попробовать остановить неработающий скрипт и перезапустить драйвер.

            Вкладка "Объекты" - далее раскрываем список с нужным экземпляром драйвера (к примеру javascript.0), далее "scriptEnabled" - группа скриптов с искомым и значение true меняем на false.

            Перезапускаем драйвер, смотрим где ошибка.

            1 Reply Last reply Reply Quote 0
            • C
              creo last edited by

              Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 30сек (я так понимаю время опроса Меги) как это обойти?

              сам скрипт:

              on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                      if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                          log(getState('svetOn').val);
                              clearTimeout(timer);
                              var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                              log(lux_kitchen);
                                  if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                                  if (flag_motion_kitchen){
                                      log('запускаем таймер отключения на 30000');
                                      timer = setTimeout(function() {
                                          setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                          flag_motion_kitchen = false;
                                          setState('svetOn',0);
                                         log("выкл свет по таймеру");
                                      },
                                      30000
                                  );}
                                  if (obj.newState.val === true && flag_motion_kitchen){
                                      setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                      setState('svetOn',3);
                                      log("вкл свет");
                                  }
                      }
              });
              
              1 Reply Last reply Reply Quote 0
              • Bluefox
                Bluefox last edited by

                @creo:

                Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 30сек (я так понимаю время опроса Меги) как это обойти?

                сам скрипт:

                on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                        if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                            log(getState('svetOn').val);
                                clearTimeout(timer);
                                var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                                log(lux_kitchen);
                                    if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                                    if (flag_motion_kitchen){
                                        log('запускаем таймер отключения на 30000');
                                        timer = setTimeout(function() {
                                            setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                            flag_motion_kitchen = false;
                                            setState('svetOn',0);
                                           log("выкл свет по таймеру");
                                        },
                                        30000
                                    );}
                                    if (obj.newState.val === true && flag_motion_kitchen){
                                        setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                        setState('svetOn',3);
                                        log("вкл свет");
                                    }
                        }
                });
                ```` `  
                

                Просто добавь первой строчкой

                перед "if (getState('onSensor').val ==…."

                if (obj.state.ack) return;
                
                
                1 Reply Last reply Reply Quote 0
                • C
                  creo last edited by

                  теперь скрипт дальше чем if (obj.state.ack) return; не отрабатывает&

                  Даже при приходящем событии о смене статуса

                  1 Reply Last reply Reply Quote 0
                  • Bluefox
                    Bluefox last edited by

                    @creo:

                    теперь скрипт дальше чем if (obj.state.ack) return; не отрабатывает&

                    Даже при приходящем событии о смене статуса А что говорит на первой строкой > console.log(typeof getState('onSensor').val) `
                    Поменяй === на ==

                    1 Reply Last reply Reply Quote 0
                    • C
                      creo last edited by

                      я сделал так:

                      var timer;
                      var flag_motion_kitchen = false;
                      on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                          console.log("до");
                          if (obj.state.ack) return;
                          console.log("после");
                          if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                              log(getState('svetOn').val);
                                  clearTimeout(timer);
                                  var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                                  log(lux_kitchen);
                                      if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                                      if (flag_motion_kitchen){
                                          log('запускаем таймер отключения на 30000');
                                          timer = setTimeout(function() {
                                              setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                              flag_motion_kitchen = false;
                                              setState('svetOn',0);
                                             log("выкл свет по таймеру");
                                          },
                                          30000
                                      );}
                                      if (obj.newState.val === true && flag_motion_kitchen){
                                          setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                          setState('svetOn',3);
                                          log("вкл свет хуй знает");
                                      }
                          }
                      });
                      

                      console.log("после"); - не работает

                      1 Reply Last reply Reply Quote 0
                      • Bluefox
                        Bluefox last edited by

                        Удали if (obj.state.ack) return;

                        я понял, что ты на движение среагировать хочешь.

                        Просто замени === на ==

                        1 Reply Last reply Reply Quote 0
                        • C
                          creo last edited by

                          Но ведь на сколько я понимаю разница в операторах только в варианте сравнения типов?

                          1 Reply Last reply Reply Quote 0
                          • C
                            creo last edited by

                            Вариант с заменой === на == не помог. Все равно самопроизвольно через каждые 30 сек свет зажигается. Какие есть ещё варианты?

                            1 Reply Last reply Reply Quote 0
                            • I
                              instalator last edited by

                              @creo:

                              Вариант с заменой === на == не помог. Все равно самопроизвольно через каждые 30 сек свет зажигается. Какие есть ещё варианты? `
                              Самопроизвольно он включается потому что объект обновляется каждые 30 секунд

                              1 Reply Last reply Reply Quote 0
                              • Bluefox
                                Bluefox last edited by

                                @creo:

                                Вариант с заменой === на == не помог. Все равно самопроизвольно через каждые 30 сек свет зажигается. Какие есть ещё варианты? `
                                Значит ты шлёшь каждые 30 секунд "1".

                                Так чего же удивляться?

                                Выведи значение в лог

                                console.log(typeof getState('onSensor').val + ' - ' + getState('onSensor').val);

                                1 Reply Last reply Reply Quote 0
                                • C
                                  creo last edited by

                                  Так он и должен срабатывать, я тогда не пойму почему если я подписался на событие датчика движения

                                  on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                                  

                                  почему он вызывается каждые 30 сек даже когда не приходит ни какого события от самого датчика (когда событие приходит срабатывает как нужно)

                                  1 Reply Last reply Reply Quote 0
                                  • I
                                    instalator last edited by

                                    @creo:

                                    Так он и должен срабатывать, я тогда не пойму почему если я подписался на событие датчика движения

                                    on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                                    

                                    почему он вызывается каждые 30 сек даже когда не приходит ни какого события от самого датчика (когда событие приходит срабатывает как нужно) ` значит прилетают разные состояния, выведи в лог и помониторь

                                    1 Reply Last reply Reply Quote 0
                                    • C
                                      creo last edited by

                                      В логе событий нет ничего кроме фактически движения (когда оно есть)

                                      1 Reply Last reply Reply Quote 0
                                      • C
                                        creo last edited by

                                        так как? вариантов больше нет?

                                        1 Reply Last reply Reply Quote 0
                                        • I
                                          instalator last edited by

                                          @creo:

                                          так как? вариантов больше нет? `
                                          Скрипт не работает пока нет изменений на megad.1.p1_Движение_гостинная,

                                          так что самопроизвольно он мигает видимо по другой причине. Попробуй останови скрипт.

                                          1 Reply Last reply Reply Quote 0
                                          • A
                                            andrey99986 last edited by

                                            Написал на Blockly программу, первая строка кода:

                                            on({id: 'javascript\\.0\\.gsm7_1_статус', change: "any"}, function (obj) {
                                            

                                            Этот код не срабатывает, наверно из-за неверного экранирования точек.

                                            На js программа работает с таким кодом:

                                            on({id: "javascript.0.gsm7_1_статус", change: "any"}, function (obj) {
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            639
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            83052
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo