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
    675

  • 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.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.
  • 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
                                      • I Offline
                                        I Offline
                                        instalator
                                        wrote on last edited by
                                        #205

                                        @creo:

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

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

                                        http://blog.instalator.ru/

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

                                          Совершенно на оборот. если остановить скрипт то ничего не включается.

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

                                          Два сообщения вверх есть лог сработки каждые 30 сек

                                          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

                                          505

                                          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