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.
  • 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
                                        • C Offline
                                          C Offline
                                          creo
                                          wrote on last edited by
                                          #204

                                          ну как же проблема не в скрипте когда срабатывает конкретная секция, о чем пишет в лог? может и не в скрипте проблема, может глубже. но я не понимаю куда дальше смотреть

                                          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

                                          269

                                          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