Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. Скрипты
    5. ioBroker скрипты
    6. Вопросы по написанию скриптов

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

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

    This topic has been deleted. Only users with topic management privileges can see it.
    • Bluefox
      Bluefox last edited by

      @spectrekr:

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

      log('This is warning', 'warn');
      
      1 Reply Last reply Reply Quote 0
      • aurodionov
        aurodionov last edited by

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

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

        1 Reply Last reply Reply Quote 0
        • Bluefox
          Bluefox last edited by

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

          1 Reply Last reply Reply Quote 0
          • aurodionov
            aurodionov last edited by

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

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

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

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

            1 Reply Last reply Reply Quote 0
            • Bluefox
              Bluefox last edited by

              @aurodionov:

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

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

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

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

              1 Reply Last reply Reply Quote 0
              • V
                vtec last edited by

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

                1 Reply Last reply Reply Quote 0
                • Bluefox
                  Bluefox last edited by

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

                  'stop;play;paused'

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

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

                  1 Reply Last reply Reply Quote 0
                  • V
                    vtec last edited by

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

                    1 Reply Last reply Reply Quote 0
                    • V
                      vtec last edited by

                      Как правильно сделать несколько таймаутов? Нужно мегой помигать через 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 Reply Quote 0
                      • I
                        instalator last edited by

                        @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);

                        1 Reply Last reply Reply Quote 0
                        • V
                          vtec last edited by

                          Спасибо, работает 🙂

                          1 Reply Last reply Reply Quote 0
                          • Bluefox
                            Bluefox last edited by

                            @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 Reply Quote 0
                            • V
                              vtec last edited by

                              `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 Reply Quote 0
                              • I
                                instalator last edited by

                                @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]
                                ``` ` 
                                1 Reply Last reply Reply Quote 0
                                • V
                                  vtec last edited by

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

                                  1 Reply Last reply Reply Quote 0
                                  • I
                                    instalator last edited by

                                    @vtec:

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

                                    1 Reply Last reply Reply Quote 0
                                    • Bluefox
                                      Bluefox last edited by

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

                                       `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 Reply Quote 0
                                      • V
                                        vtec last edited by

                                        Можно ли как то отследить изменение объекта, если в этот объект происходит запись одного и того же значения (например: 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 Reply Quote 0
                                        • Bluefox
                                          Bluefox last edited by

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

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

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            999
                                            Online

                                            31.7k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            84266
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo