Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Вопросы по написанию скриптов

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    662

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.7k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

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

Scheduled Pinned Locked Moved ioBroker скрипты
358 Posts 29 Posters 116.1k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • E Offline
    E Offline
    electric
    wrote on last edited by
    #180

    @andrey99986:

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

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

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

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

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

    1 Reply Last reply
    0
    • C Offline
      C Offline
      creo
      wrote on last edited by
      #181

      Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 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
      0
      • BluefoxB Offline
        BluefoxB Offline
        Bluefox
        wrote on last edited by
        #182

        @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
        0
        • C Offline
          C Offline
          creo
          wrote on last edited by
          #183

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

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

          1 Reply Last reply
          0
          • BluefoxB Offline
            BluefoxB Offline
            Bluefox
            wrote on last edited by
            #184

            @creo:

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

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

            1 Reply Last reply
            0
            • C Offline
              C Offline
              creo
              wrote on last edited by
              #185

              я сделал так:

              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
              0
              • BluefoxB Offline
                BluefoxB Offline
                Bluefox
                wrote on last edited by
                #186

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

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

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

                1 Reply Last reply
                0
                • C Offline
                  C Offline
                  creo
                  wrote on last edited by
                  #187

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

                  1 Reply Last reply
                  0
                  • C Offline
                    C Offline
                    creo
                    wrote on last edited by
                    #188

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

                    1 Reply Last reply
                    0
                    • I Offline
                      I Offline
                      instalator
                      wrote on last edited by
                      #189

                      @creo:

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

                      Высокий уровень Децибел вреден для здоровья!

                      http://blog.instalator.ru/

                      1 Reply Last reply
                      0
                      • BluefoxB Offline
                        BluefoxB Offline
                        Bluefox
                        wrote on last edited by
                        #190

                        @creo:

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

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

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

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

                        1 Reply Last reply
                        0
                        • C Offline
                          C Offline
                          creo
                          wrote on last edited by
                          #191

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

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

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

                          1 Reply Last reply
                          0
                          • I Offline
                            I Offline
                            instalator
                            wrote on last edited by
                            #192

                            @creo:

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

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

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

                            Высокий уровень Децибел вреден для здоровья!

                            http://blog.instalator.ru/

                            1 Reply Last reply
                            0
                            • C Offline
                              C Offline
                              creo
                              wrote on last edited by
                              #193

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

                              1 Reply Last reply
                              0
                              • C Offline
                                C Offline
                                creo
                                wrote on last edited by
                                #194

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

                                1 Reply Last reply
                                0
                                • I Offline
                                  I Offline
                                  instalator
                                  wrote on last edited by
                                  #195

                                  @creo:

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

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

                                  Высокий уровень Децибел вреден для здоровья!

                                  http://blog.instalator.ru/

                                  1 Reply Last reply
                                  0
                                  • A Offline
                                    A Offline
                                    andrey99986
                                    wrote on last edited by
                                    #196

                                    Написал на 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
                                    0
                                    • BluefoxB Offline
                                      BluefoxB Offline
                                      Bluefox
                                      wrote on last edited by
                                      #197

                                      @andrey99986:

                                      Написал на 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
                                      0
                                      • C Offline
                                        C Offline
                                        creo
                                        wrote on last edited by
                                        #198

                                        @instalator:

                                        @creo:

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

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

                                        Не, остановка не помогает. И мигает он четко каждые 30 сек:

                                        ! ` > 22:10:37.074 [info] javascript.0 script.js.common.test_on: 0

                                        22:10:37.074 [info] javascript.0 script.js.common.test_on: 0

                                        22:10:37.074 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:10:37.074 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:10:42.066 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:11:12.068 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:11:37.058 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:37.059 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:37.059 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:11:37.059 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:11:42.058 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:12:12.059 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:12:42.059 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру `

                                        Еще раз код:

                                        Переменные

                                        svetOn (1 = если свет был включен с кнопки)

                                        onSensor (1 = если включено использование датчика движения)

                                        ! ````
                                        var timer;
                                        var flag_motion_kitchen = false;
                                        on({id: "megad.1.p1_Движение_гостинная"/Движение_гостинная/, change: 'ne'}, function (obj) {
                                        //if (obj.state.ack) return;
                                        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 === true){
                                        log('запускаем таймер отключения на 30000');
                                        timer = setTimeout(function() {
                                        setState("megad.1.p10_Свет_гостинная"/Свет_гостинная/, 0);
                                        flag_motion_kitchen = false;
                                        setState('svetOn',0);
                                        log("выкл свет по таймеру");
                                        },
                                        5000
                                        );}
                                        if (obj.newState.val === true && flag_motion_kitchen){
                                        setState("megad.1.p10_Свет_гостинная"/Свет_гостинная/, 255);
                                        setState('svetOn',3);
                                        log("вкл свет хуй знает");
                                        }
                                        }
                                        });

                                        1 Reply Last reply
                                        0
                                        • BluefoxB Offline
                                          BluefoxB Offline
                                          Bluefox
                                          wrote on last edited by
                                          #199

                                          > Не, остановка не помогает.
                                          Это не скрипт. Ищи ошибку в другом месте

                                          1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          268

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe