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
    658

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

    @spectrekr:

    Вопрос, а как в лог записать сообщение с пометкой warn? `

    log('This is warning', 'warn');
    
    1 Reply Last reply
    0
    • aurodionovA Offline
      aurodionovA Offline
      aurodionov
      wrote on last edited by
      #17

      Извиняюсь, может н в ту ветку.

      По логированию, какие ещё есть варианты,(info,warning,error) знаю

      Пишу с пульта….

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

        > По логированию, какие ещё есть варианты,(info,warning,error) знаю
        debug

        1 Reply Last reply
        0
        • aurodionovA Offline
          aurodionovA Offline
          aurodionov
          wrote on last edited by
          #19

          А возможно например создать свой уровень

           function(code){ 
          if (code !== 0) { 
          log('что-то там: ' + code); 
          } else {
          log('OK');
          }
          

          и его логировать отдельно,а ещё лучше засунуть его в переменную или типа того.

          Тогда появится возможность вести что-то вроде лога событий которые происходят (например работают из скриптов)

          Пишу с пульта….

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

            @aurodionov:

            А возможно например создать свой уровень

             function(code){ 
            if (code !== 0) { 
            log('что-то там: ' + code); 
            } else {
            log('OK');
            }
            

            и его логировать отдельно,а ещё лучше засунуть его в переменную или типа того.

            Тогда появится возможность вести что-то вроде лога событий которые происходят (например работают из скриптов) `
            Нет нельзя. И я пока не понял зачем ещё. Если хочешь, то можешь сам писать в переменную список событий.

            1 Reply Last reply
            0
            • V Offline
              V Offline
              vtec
              wrote on last edited by
              #21

              Bluefox, можно привести пару пример для чего можно использовать enums?

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

                Например состояния плеера:

                'stop;play;paused'

                Тогда значения состояния 0,1 и 2 автоматически будут показыватся в admin, как stop, play…

                Вот в принципе и всё.

                1 Reply Last reply
                0
                • V Offline
                  V Offline
                  vtec
                  wrote on last edited by
                  #23

                  А в виде кода можно как нибудь изобразить?

                  1 Reply Last reply
                  0
                  • V Offline
                    V Offline
                    vtec
                    wrote on last edited by
                    #24

                    Как правильно сделать несколько таймаутов? Нужно мегой помигать через 2 сек.

                    Вот так срабатывает первый setTimeout

                    var url = 'http://192.168.0.14/sec/?cmd=7:2';

                    request(url);

                    setTimeout(function(){ request(url); }, 2000);

                    setTimeout(function(){ request(url); }, 2000);

                    setTimeout(function(){ request(url); }, 2000);

                    Если делаю вложенные, то работает, но так ведь и запутаться можно.

                    setTimeout(function(){

                    request(url);

                    setTimeout(function(){ request(url); }, 2000);

                    }, 2000);

                    Есть ли более красивый/правильный пример?

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

                      @vtec:

                      Как правильно сделать несколько таймаутов? Нужно мегой помигать через 2 сек.

                      Вот так срабатывает первый setTimeout

                      var url = 'http://192.168.0.14/sec/?cmd=7:2';

                      request(url);

                      setTimeout(function(){ request(url); }, 2000);

                      setTimeout(function(){ request(url); }, 2000);

                      setTimeout(function(){ request(url); }, 2000);

                      Если делаю вложенные, то работает, но так ведь и запутаться можно.

                      setTimeout(function(){

                      request(url);

                      setTimeout(function(){ request(url); }, 2000);

                      }, 2000);

                      Есть ли более красивый/правильный пример? `
                      setTimeout

                      var url = 'http://192.168.0.14/sec/?cmd=7:2';

                      request(url);

                      setTimeout(function(){ request(url); }, 2000);

                      setTimeout(function(){ request(url); }, 4000);

                      setTimeout(function(){ request(url); }, 6000);

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

                      http://blog.instalator.ru/

                      1 Reply Last reply
                      0
                      • V Offline
                        V Offline
                        vtec
                        wrote on last edited by
                        #26

                        Спасибо, работает :)

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

                          @instalator:

                          @vtec:

                          Как правильно сделать несколько таймаутов? Нужно мегой помигать через 2 сек.

                          Вот так срабатывает первый setTimeout

                          var url = 'http://192.168.0.14/sec/?cmd=7:2';

                          request(url);

                          setTimeout(function(){ request(url); }, 2000);

                          setTimeout(function(){ request(url); }, 2000);

                          setTimeout(function(){ request(url); }, 2000);

                          Если делаю вложенные, то работает, но так ведь и запутаться можно.

                          setTimeout(function(){

                          request(url);

                          setTimeout(function(){ request(url); }, 2000);

                          }, 2000);

                          Есть ли более красивый/правильный пример? `
                          setTimeout

                          var url = 'http://192.168.0.14/sec/?cmd=7:2';

                          request(url);

                          setTimeout(function(){ request(url); }, 2000);

                          setTimeout(function(){ request(url); }, 4000);

                          setTimeout(function(){ request(url); }, 6000); `

                          Правильнее будет сделать так:

                          var url = 'http://192.168.0.14/sec/?cmd=7:2';
                          
                          function blink(count) {
                             if (count === undefined) count = 0;
                             if (count > 3) return;
                             request(url);
                             setTimeout(blink, 2000, count + 1);
                          }
                          
                          blink();
                          
                          
                          1 Reply Last reply
                          0
                          • V Offline
                            V Offline
                            vtec
                            wrote on last edited by
                            #28
                            `var idSayIt = "sayit.0.tts.text";
                            var message = [];
                            message.push('Доброе утро.');
                            message.push('За окном 7 градусов.');
                            message.push('Прогноз погоды на завтра');
                            
                            for(var i=0; i<message.length; i++){/setstate/(idsayit,/message[i]);/log(message[i]);/}<e=""></message.length;>`
                            
                            Почему данный код работает не корректно, то есть может второе сообщение проговорить два раза, а последнее не произнести?[/i][/i]
                            
                            1 Reply Last reply
                            0
                            • I Offline
                              I Offline
                              instalator
                              wrote on last edited by
                              #29

                              @vtec:

                              `var idSayIt = "sayit.0.tts.text";
                              var message = [];
                              message.push('Доброе утро.');
                              message.push('За окном 7 градусов.');
                              message.push('Прогноз погоды на завтра');
                              
                              for(var i=0; i<message.length; i++){/setstate/(idsayit,/message[i]);/log(message[i]);/}<e=""></message.length;>`
                              
                              Почему данный код работает не корректно, то есть может второе сообщение проговорить два раза, а последнее не произнести?
                              А в лог норм выводит?[/i][/i]
                              ``` ` 

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

                              http://blog.instalator.ru/

                              1 Reply Last reply
                              0
                              • V Offline
                                V Offline
                                vtec
                                wrote on last edited by
                                #30

                                В лог да, нормально

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

                                  @vtec:

                                  В лог да, нормально `
                                  Данные пишутся без задержки, я думаю в этом причина, может сделать опрос закончилось ли прогаваривание текущего потом подавать на вывод следующие данные

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

                                  http://blog.instalator.ru/

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

                                    Попробуй так:

                                     `var idSayIt = "sayit.0.tts.text";
                                    var message = [];
                                    message.push({text: 'Доброе утро.', interval: 3000});
                                    message.push({text: 'За окном 7 градусов.', interval: 4000});
                                    message.push({text: 'Прогноз погоды на завтра', interval: 5000});
                                    
                                    var interval = 0;
                                    for(var i=0; i<message.length; i++){/settimeout(function/(text)/{/setstate/(idsayit,/text);/log(text);/},/interval,/message[i].text);/interval/+="message[i].interval;" }<e=""></message.length;>`
                                      [2678_error.png](/assets/uploads/files/2678_error.png)  [/i][/i]
                                    
                                    1 Reply Last reply
                                    0
                                    • V Offline
                                      V Offline
                                      vtec
                                      wrote on last edited by
                                      #33

                                      Можно ли как то отследить изменение объекта, если в этот объект происходит запись одного и того же значения (например: up), но с интервалом например в 2-3 секунды?

                                      Я пока только так придумал:

                                      on('javascript.0.kodi.ExecuteAction',function (obj) {
                                          if(obj.newState.val !== false){
                                              sendCommand(obj.newState.val);
                                              setState('javascript.0.kodi.ExecuteAction', false)
                                       }
                                      });
                                      

                                      Может лучше есть решение?

                                      1 Reply Last reply
                                      0
                                      • BluefoxB Offline
                                        BluefoxB Offline
                                        Bluefox
                                        wrote on last edited by
                                        #34
                                        on({id: 'javascript.0.kodi.ExecuteAction', change: 'any'}, function (obj) {
                                                sendCommand(obj.newState.val);
                                        });
                                        
                                        1 Reply Last reply
                                        0
                                        • V Offline
                                          V Offline
                                          vtec
                                          wrote on last edited by
                                          #35

                                          Отличное решение, спасибо ;)

                                          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

                                          567

                                          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