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
    687

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

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

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

Scheduled Pinned Locked Moved ioBroker скрипты
358 Posts 29 Posters 116.2k 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.
  • 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
                                  • C Offline
                                    C Offline
                                    creo
                                    wrote on last edited by
                                    #200

                                    Это конечно прикольно, но я не далекий от написания кода. Каждые 30 сек срабатывает подписка на событие датчика движения. но сам датчик молчит.более я не знаю откуда еще он может вызываться

                                    Где еще можно посмотреть?

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

                                      А ты можешь встроить вот такой лог?

                                      log('svetOn: ' + getState('svetOn').val + ', p1_Движение_гостинная: ' + obj.state.val + '[ack: ' + obj.state.ack + '], onSensor: ' + getState('onSensor').val);
                                      
                                      
                                      1 Reply Last reply
                                      0
                                      • C Offline
                                        C Offline
                                        creo
                                        wrote on last edited by
                                        #202
                                        megad-1	2016-09-20 23:48:16.125	info	try to control megad.1.p10_Свет_гостинная with 0
                                        javascript-0	2016-09-20 23:48:11.215	info	script.js.common.test_on: svetOn: 3, p1_Движение_гостинная: false[ack: true], onSensor: 1
                                        megad-1	2016-09-20 23:48:11.134	info	try to control megad.1.p10_Свет_гостинная with 255
                                        
                                        1 Reply Last reply
                                        0
                                        • I Offline
                                          I Offline
                                          instalator
                                          wrote on last edited by
                                          #203

                                          @creo:

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

                                          Т.е проблема не в скрипта

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

                                          http://blog.instalator.ru/

                                          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

                                          556

                                          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